原文链接:http://www.cnblogs.com/shuoer/p/7779131.html

用systemJS+karma+Jasmine+babel环境去编写简单的ES6工程

首先解释下什么事systemJS、karma、Jasmine、babel

  • SystemJS是万能动态模块加载器github
  • Karma是一个基于Node.js的JavaScript测试执行过程管理工具(Test Runner)。该工具可用于测试所有主流Web浏览器,也可集成到CI(Continuous integration)工具,也可和其他代码编辑器一起使用。这个测试工具的一个强大特性就是,它可以监控(Watch)文件的变化,然后自行执行,通过console.log显示测试结果。karma官网
  • Jasmine是单元测试框架,jasmine很有意思的提出了BDD(Behavior Driven Development)行为驱动开发,测试先行的概念jasmine官网
  • Babel 是一个 JavaScript 编译器。Babel 用于转化你的 JavaScript 代码babel官网

初始化一个工程

//创建一个工程目录并切换到该目录下
mkdir karmatest && cd karmatest
//初始化一个工程,得到package.json来管理我们项目中的包依赖
npm init

安装karma

//首先需要全局安装karma的命令行工具(已经有的略过)
npm install -g karma-cli
//安装karma到我当前项目中并添加到本地的依赖
npm install karma --save-dev
//初始化karma得到karma的配置文件karma.conf.js
karma init


先执行下karma start 看看karma安装成功了没?好像报错了!

从错误提示可以看出来karma 连接jasmine-core的时候报错了,缺少jasmine-core包!俩字,安装!

//安装jasmine-core并添加到本地的版本依赖中
npm install jasmine-core --save-dev
//安装成功之后我们再执行下karma start测试下karma是否安装成功
karma start


可以看出我们karma安装成功了,只是没有任何的测试用例,接下来我们配置下karma.conf.js和写下我们的测试用例

//修改karma.conf.js两处
//第一处告诉karma业务代码和测试代码在哪
files: [
'./src/utils/*.js',
'./test/**/*.spec.js'
]
//第二处把karma的持续集成模式打开,让karma去自动捕获浏览器测试结束和退出
singleRun: true

接下来我们创建src和test目录和编写业务代码和测试用例

//创建业务代码在src下的utils下创建index.js代码如下
function add(num){
return ++num
}
//创建我们的测试用例test目录下编写测试用例test.spec.js代码如下
//此处测试用例是jasmine的语法请参阅jasmine的官网
//jasmine 官网https://jasmine.github.io/edge/introduction.html
describe('测试加法函数',function(){
it('测试add(1)是否等于2',function(){
expect(add(1)).toEqual(2);
})
})
//保存好之后我们再次执行karma start

ok 到此处我们的单元测试已经做好了,我们编辑package.json让项目执行npm test就可以跑我们写好的测试用例

{
"name": "karmatest",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "karma start"//此处支持npm test跑我们的karma start
},
"author": "",
"license": "ISC",
"devDependencies": {
"jasmine-core": "^2.8.0",
"karma": "^1.7.1",
"karma-jasmine": "^1.1.0",
"karma-phantomjs-launcher": "^1.0.4"
}
}

配置systemJS+Babel动态引用并解析我们的es6代码

由于systemJS需要我们起一个server所以我们先装个server
server你可以随意起,能起来就行,此处我用的是serve

安装本地serve

//全局安装一个serve
npm install serve -g
//将serve安装进我们的项目中并添加进项目的版本依赖中
npm install serve --save-dev
//测试serve是否安装成功
serve


安装systemJS

//安装systemjs和systemjs-plugin-babel并添加进版本依赖中
npm install systemjs systemjs-plugin-babel --save-dev

在src目录下创建一个indexclass.js文件添加如下内容

/**
* 引入我们单元测试创建的add方法
*/
import './utils/index.js'
/**
* 创建一个person类
*/
class Person{
/**
* [constructor description]
* @param {[type]} name [名称]
* @param {Number} num [调用次数]
* @return {[type]} [description]
*/
constructor(name,num=0){
this.name = name
this.num = num
}
/**
* [speak 该方法返回当前实例的名称和调用次数]
* @return {[type]} [description]
*/
speak(){
this.num = add(this.num)
return `我的名字叫${this.name}你调了我${this.num}次`
}
}
/**
* [create 用于创建person类的实例化]
* @param {[type]} name [description]
* @return {[type]} [description]
*/
export const create = (name,num)=>{
let p = new Person(name,num)
return p
}

在我们项目的根目录创建index.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<!-- 首先把systemjs引进来 -->
<script src="./node_modules/systemjs/dist/system.js"></script>
</head>
<body>
<script>
/**
* [SystemJS.config SystemJS的配置文件]
* [baseURL ]
* [map ]
* @type {String}
*/
SystemJS.config({
baseURL:'./',
transpiler:'plugin-babel',
map:{
'plugin-babel':'node_modules/systemjs-plugin-babel/plugin-babel.js',
'systemjs-babel-build':'node_modules/systemjs-plugin-babel/systemjs-babel-browser.js'
}
});
/**
* [用SystemJS去加载我们的es6模块文件]
* @param {[type]} compoent [description]
* @return {[type]} [description]
*/
SystemJS.import('./src/indexclass.js').then(compoent=>{
/**
* [compoent component 是我们indexclass文件export的方法此处我们export了个create方法]
* [create 次方法是一个类似的工厂函数,用于创建出一个一个的实例]
* @type {[type]}
*/
// 实例化一个zhangsan
var zhangsan = compoent.create('zhangsan')
// 实例化一个lisi
var lisi = compoent.create('lisi')
console.log(zhangsan.speak())
console.log(zhangsan.speak())
console.log(zhangsan.speak())
console.log(lisi.speak())
})
</script>
</body>
</html>

ok 最后再配置下package.json文件支持npm start 启动服务
完整的package.json如下

{
"name": "karmatest",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"start":"serve",
"test": "karma start"
},
"author": "",
"license": "ISC",
"devDependencies": {
"jasmine-core": "^2.8.0",
"karma": "^1.7.1",
"karma-jasmine": "^1.1.0",
"karma-phantomjs-launcher": "^1.0.4",
"serve": "^6.4.0",
"systemjs": "^0.20.19",
"systemjs-plugin-babel": "0.0.25"
}
}

测试下我们的成果

//跑单元测试
npm test
//启动服务
npm start


【转】用systemJS+karma+Jasmine+babel环境去编写简单的ES6工程的更多相关文章

  1. Karma+Jasmine测试环境搭建

    1.如果你还没安装node的话,去这里下载:http://nodejs.cn/download/,选择跟你电脑匹配的并进行安装,一路next下来就行,路径最好改成自己让自己舒服的,默认的路径可能会很让 ...

  2. premake在Ubuntu和GCC环境下创建简单的C++工程

    由于premake基于lua脚本,为了方便编辑lua脚本,我在emacs24中利用package system安装了lua-mode. 然后创建config.lua文件,填入下面这段,主要来自:htt ...

  3. 学习Karma+Jasmine+istanbul+webpack自动化单元测试

    学习Karma+Jasmine+istanbul+webpack自动化单元测试 1-1. 什么是karma?  Karma 是一个基于Node.js的Javascript测试执行过程管理工具.该工具可 ...

  4. 使用karma+jasmine做单元测试

    目的 使用karma和jasmine来配置自动化的js单元测试. Karma和Jasmine Karma是由Angular团队所开发的一种自动化测试工具.链接:http://karma-runner. ...

  5. angular测试-Karma + Jasmine配置

    首先讲一下大致的流程: 需要node环境,首先先要安装node,node不会?请自行搜索.版本>0.8 安装node完成之后先要测试下npm是否测试通过,如下图所示 首先看下目录结构 目录为:F ...

  6. Karma +Jasmine+ require JS进行单元测试并生成测试报告、代码覆盖率报告

    1. 关于Karma Karma是一个基于Node.js的JavaScript测试执行过程管理工具(Test Runner). 该工具可用于测试所有主流Web浏览器,也可集成到CI(Continuou ...

  7. angularJS测试一 Karma Jasmine Mock

    AngularJS测试 一 测试工具 1.NodeJS领域:Jasmine做单元测试,Karma自动化完成单元测试,Grunt启动Karma统一项目管理,Yeoman最后封装成一个项目原型模板,npm ...

  8. 在WebStorm中集成Karma+jasmine进行前端单元测试

    在WebStorm中集成Karma+jasmine进行前端单元测试 前言 好久没有写博了,主要还是太懒=.=,有点时间都去带娃.看书了,今天给大家分享一个原创的小东西,如果大家对TDD或者BDD有兴趣 ...

  9. 搭建Karma+Jasmine的自动化单元测试

    最近在打算将以前的代码进行重构,过程中发现自己不写自动化测试代码,而是手动的写,这样并不好,所以就学了Karma+Jasmine的自动化单元测试,以后写代码尽量要写自动化单元测试,也要测一下istan ...

随机推荐

  1. iOS 通讯录空格

    iOS 通讯录联系人出现 ASCII 码值为 160 的空格  NOTE:       这里的"空格"是指 在通讯录中取出的联系人中带有特殊空格 带有特殊空格的字符串 " ...

  2. Spring中的注入方式

    在Spring配置文件中使用XML文件进行配置,实际上是让Spring执行了相应的代码,例如: 使用<bean>元素,实际上是让Spring执行无参或有参构造器 使用<propert ...

  3. 做直线不要使用hr

    需要横线.竖线时不要使用hr标签来做,容易出问题,可以使用高度或宽度为1px并加上背景色的div.p代替.

  4. ssm框架的整合

    首先创建一个web工程,我这里使用的IDE为eclipse. 结果目录如下: 添加相关的jar包: 接下来是完成配置文件 首先我们先配置web.xml: <?xml version=" ...

  5. python函数下篇装饰器和闭包,外加作用域

    装饰器和闭包的基础概念 装饰器是一种设计模式能实现代码重用,经常用于查日志,性能测试,事务处理等,抽离函数大量不必的功能. 装饰器:1.装饰器本身是一个函数,用于装饰其它函数:2.功能:增强被装饰函数 ...

  6. 三、第一个IDEA创建的MAVEN工程——JavaWeb点滴

    一.Maven是什么? Maven是一个项目管理工具,它包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个 ...

  7. HDU 4325 Flowers(树状数组)

    Flowers Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  8. sass学习--在htm文件中使用

    一.导语 最近的战狼2好火爆啊,每天看战狼2的票房一路高飙,我估计比吴京还开心.看了这部戏的拍摄过程,除了敬佩就是踏实,是的,吴京是电影圈隔了这么久后能踏踏实实做电影的了,纯属个人见解,不喜请忽略.. ...

  9. CodeForces - 706B 二分stl

    #include<iostream> #include<cstdio> #include<cstring> #include<string> #incl ...

  10. NoSQL:redis缓存数据库

    一 Redis介绍 Redis和Memcached类似,也属于key-value nosql 数据库 Redis官网redis.io, 当前最新稳定版4.0.1 和Memcached类似,它支持存储的 ...