http://www.tuicool.com/articles/rAnaYvn
直奔主题:
一、安装grunt-contrib-qunit
npm install grunt-contrib-qunit --save-dev (前提先安装nodejs和npm)
自动下载grunt-lib-phantomjs库,安装phantomJS
phantomjs实现了一个无界面的webkit浏览器。虽然没有界面,但dom渲染、js运行、网络访问、canvas/svg绘制等功能都很完备,在页面抓取、页面输出、自动化测试广泛应用
二、在Gruntfile.js当中载入grunt-contrib-qunit
grunt.loadNpmTasks('grunt-contrib-qunit');
三、创建测试任务
配置选项:
timeout:超时,默认5000,毫秒为单位,等待qunit的start()有错误失败的任务之前调用。
inject:备注,备注到bridge文件
httpBase:字符串,默认为false。创建在源文件的URL,所有的源文件的前缀。
console:布尔值,默认true。设置隐藏phantomJS 控制台输出。
urls:数组,配置测试地址,允许多个地址访问
force:布尔值,默认为false。有个任务失败后面即停止
初始化配置:
测试相对地址文件:
grunt.initConfig({
qunit: {
all: ['test/**/*.html']
}});
测试http页面地址:
grunt.initConfig({
qunit: {
all: {
options: {
urls: [
'http://localhost:8000/test/foo.html',
'http://localhost:8000/test/bar.html'
]
}
}
},
connect: {
server: {
options: {
port: 8000,
base: '.'
}
}
}
});
grunt.loadNpmTasks('grunt-contrib-connect');
grunt.registerTask('test', ['connect', 'qunit']);
grunt test
data:image/s3,"s3://crabby-images/55344/55344b170e44097f873c9045728ac648fde5076f" alt=""
查了一下问题:发现没有测试用例。
汇总:整个单测结构体如下
node_modules
test
-- libs
-- qunit.css
-- qunit.js
-- qunit1.html
-- qunit2.html
-- qunit3.html
-- qunit_noglobal_test.js
-- qunit_test.js
-- qunit_test_error.js
Gruntfile.js
package.json
接下来开始详细分解各个文件:
grunt配置json文件:package.json
data:image/s3,"s3://crabby-images/f992f/f992f9aae949e97f5cca35841a095cca56b024fb" alt=""
data:image/s3,"s3://crabby-images/0847d/0847d17ad730a3a4053f7e88a51529dbf94c14bf" alt=""
grunt执行文件Gruntfile.js
data:image/s3,"s3://crabby-images/9ceb1/9ceb167f297c13235f70a9bd1765397379c6a7a8" alt=""
data:image/s3,"s3://crabby-images/b7f01/b7f0166277549454e20be77683a518e90e6540a6" alt=""
测试文件qunit1.html,qunit2.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>基本测试页面</title>
<!-- 载入本地测试套件. -->
<link rel="stylesheet" href="test/libs/qunit.css" media="screen">
<script src="test/libs/qunit.js"></script>
<!-- 载入本地测试用例 -->
<script src="test/qunit_test.js"></script>
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture">内容很丰富</div>
</body>
</html>
<html>
<head>
<meta charset="utf-8">
<title>基本测试页面</title>
<!-- 载入本地测试套件. -->
<link rel="stylesheet" href="test/libs/qunit.css" media="screen">
<script src="test/libs/qunit.js"></script>
<!-- 载入本地测试用例 -->
<script src="test/qunit_test.js"></script>
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture">内容很丰富</div>
</body>
</html>
测试文件qunit3.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>基本测试页面</title>
<!-- 载入本地测试套件 -->
<link rel="stylesheet" href="libs/qunit.css" media="screen">
<script src="libs/qunit.js"></script>
<!-- 载入本地测试用例 -->
<script src="qunit_noglobal_test.js"></script>
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture">非全局检查</div>
</body>
</html>
<html>
<head>
<meta charset="utf-8">
<title>基本测试页面</title>
<!-- 载入本地测试套件 -->
<link rel="stylesheet" href="libs/qunit.css" media="screen">
<script src="libs/qunit.js"></script>
<!-- 载入本地测试用例 -->
<script src="qunit_noglobal_test.js"></script>
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture">非全局检查</div>
</body>
</html>
libs/qunit.css文件(测试框架css文件)
字体模块:
data:image/s3,"s3://crabby-images/d3fba/d3fba3d77273137a6b0625be8ea7eb126f5cb317" alt=""
初始化:
data:image/s3,"s3://crabby-images/41acd/41acd9e6f976698df5541f30460e804136672233" alt=""
头部模块:
data:image/s3,"s3://crabby-images/dee92/dee92e1c51890b0d314fcf0e8148db37a273af10" alt=""
测试状态:
data:image/s3,"s3://crabby-images/ac2d8/ac2d85893277de00bac17255c130fa1f0b37ee7b" alt=""
测试计数:
data:image/s3,"s3://crabby-images/898a3/898a307b517d1484ae3496ac7b0be790b13f07b1" alt=""
通过测试样式:
data:image/s3,"s3://crabby-images/bcd29/bcd29ab79e8fae3983e13f82cb4e5fbaa6463a74" alt=""
失败样式:
data:image/s3,"s3://crabby-images/c3876/c38769fa36efbf9ec23678f087289866eef02e56" alt=""
测试结果:
data:image/s3,"s3://crabby-images/dbaa6/dbaa6957ad6470a3af0a6a858d84a931e7b3a52d" alt=""
libs/qunit.js(js单元测试框架)
下载地址:http://download.csdn.net/detail/zqjflash/7981109
测试用例:qunit_test.js
test('basic test', function() {
expect(1);
ok(true, '内容很丰富');
});
test('can access the DOM', function() {
expect(1);
var fixture = document.getElementById('qunit-fixture');
equal(fixture.innerText, '内容很丰富', 'should be able to access the DOM.');
});
expect(1);
ok(true, '内容很丰富');
});
test('can access the DOM', function() {
expect(1);
var fixture = document.getElementById('qunit-fixture');
equal(fixture.innerText, '内容很丰富', 'should be able to access the DOM.');
});
测试用例:qunit_test_error.js
data:image/s3,"s3://crabby-images/066a7/066a7225812eb4cfcff5f5097e4d41593dc3d2b1" alt=""
测试用例:qunit_noglobal_test.js
data:image/s3,"s3://crabby-images/13dee/13dee1dbf6b36adb20331120d30df110572068de" alt=""
各目录详情分布:
node_modules
data:image/s3,"s3://crabby-images/3c191/3c191f63bb40a50a02002ced1788a9ba0ada44f6" alt=""
test目录
data:image/s3,"s3://crabby-images/f8441/f844193a470522b6e2cb23f15e6acbada7091f5f" alt=""
libs目录:
data:image/s3,"s3://crabby-images/f8e31/f8e31305b8ac58d273aba27bfa2f9e2a3a4f2583" alt=""
页面测试文件:
data:image/s3,"s3://crabby-images/bd932/bd9322553ee40477821148188c3789df2fe62ab2" alt=""
再次执行grunt test
data:image/s3,"s3://crabby-images/8e521/8e521347c021181dd59c199c58081a767ecc123c" alt=""
看到Done,第一个自动化测试demo跑通了。