在单元测试中重置模块
Reset module in unit tests
我有一个使用以下模式创建的 requirejs 模块:
// foo.js
define(function(){
var x = 0;
function doStuff(){
return ++x;
}
return { doStuff: doStuff };
});
还有一个看起来像这样的 QUnit 测试:
// testfoo.js
define(['QUnit, foo'], function(QUnit, foo){
function setup(){
//...?
}
function teardown(){
//...?
}
function runTests(){
QUnit.test('foo counter remains at 1 on multiple tests', function(assert){
assert.equal(foo.doStuff(), 1); // this will work
});
QUnit.test('foo counter remains at 1 on multiple tests', function(assert){
assert.equal(foo.doStuff(), 1); // this obviously won't
});
}
return runTests;
});
如何为每个测试重置 foo
?
我想保留 foo
一个揭示模块,即不将其转换为具有更改原型的构造函数。
我试过 var foo = require('foo');
,但是由于 requirejs 是基于 AMD 的,它会抱怨加载顺序错误。
虽然这肯定不是最简洁的方法,但通过将函数保存为字符串,并在每次测试之前重新创建函数,您可以达到相同的效果。
var fooString = foo.toString();
QUnit.testStart(function() { eval('foo = ' + fooString});
我建议查看 SquireJS 为您的测试创建一个独立的上下文。 Squire 旨在通过创建隔离的 RequireJS 上下文来注入模拟依赖项。这样做的副作用是每次调用 injector.require() 时 'foo' 库都会重新加载,从而重置库的状态。唯一的缺点是您的测试需要异步。
// testfoo.js
define(['Squire', 'foo'], function (Squire, foo) {
'use strict';
QUnit.start();
QUnit.module('foo', {
setup: function () {
},
teardown: function () {
}
});
QUnit.test('Testing foo counter in main context.', 2, function (assert) {
assert.equal(foo.doStuff(), 1); // this will work
assert.equal(foo.doStuff(), 2); // this should work also.
});
QUnit.test('Testing foo counter in context created by Squire.', 1, function (assert) {
var done = assert.async(),
injector = new Squire();
injector.require([
'foo'
], function (foo) {
assert.equal(foo.doStuff(), 1); // this will work.
done();
});
});
});
我在这里发布了一个示例项目:qunit-squirejs
我有一个使用以下模式创建的 requirejs 模块:
// foo.js
define(function(){
var x = 0;
function doStuff(){
return ++x;
}
return { doStuff: doStuff };
});
还有一个看起来像这样的 QUnit 测试:
// testfoo.js
define(['QUnit, foo'], function(QUnit, foo){
function setup(){
//...?
}
function teardown(){
//...?
}
function runTests(){
QUnit.test('foo counter remains at 1 on multiple tests', function(assert){
assert.equal(foo.doStuff(), 1); // this will work
});
QUnit.test('foo counter remains at 1 on multiple tests', function(assert){
assert.equal(foo.doStuff(), 1); // this obviously won't
});
}
return runTests;
});
如何为每个测试重置 foo
?
我想保留 foo
一个揭示模块,即不将其转换为具有更改原型的构造函数。
我试过 var foo = require('foo');
,但是由于 requirejs 是基于 AMD 的,它会抱怨加载顺序错误。
虽然这肯定不是最简洁的方法,但通过将函数保存为字符串,并在每次测试之前重新创建函数,您可以达到相同的效果。
var fooString = foo.toString();
QUnit.testStart(function() { eval('foo = ' + fooString});
我建议查看 SquireJS 为您的测试创建一个独立的上下文。 Squire 旨在通过创建隔离的 RequireJS 上下文来注入模拟依赖项。这样做的副作用是每次调用 injector.require() 时 'foo' 库都会重新加载,从而重置库的状态。唯一的缺点是您的测试需要异步。
// testfoo.js
define(['Squire', 'foo'], function (Squire, foo) {
'use strict';
QUnit.start();
QUnit.module('foo', {
setup: function () {
},
teardown: function () {
}
});
QUnit.test('Testing foo counter in main context.', 2, function (assert) {
assert.equal(foo.doStuff(), 1); // this will work
assert.equal(foo.doStuff(), 2); // this should work also.
});
QUnit.test('Testing foo counter in context created by Squire.', 1, function (assert) {
var done = assert.async(),
injector = new Squire();
injector.require([
'foo'
], function (foo) {
assert.equal(foo.doStuff(), 1); // this will work.
done();
});
});
});
我在这里发布了一个示例项目:qunit-squirejs