如何在单元测试时模拟特定的RequireJs依赖项

时间:2015-06-10 03:15:27

标签: javascript unit-testing testing mocking dependencies

我在浏览器中使用qUnit对我的宠物项目进行单元测试。我单元测试的模块可能如下所示:

// Filename: views/base.js

define(['../manager'], function(Manager){

  return Backbone.View.extend({

   //...

});

我想模仿依赖"../manager"(manager.js) 我尝试使用testr.jsSquire.js这两个建议修改路径配置的路径。

示例:

testr.config({
    root: '../',
    baseUrl: 'src',
    stubUrl: 'tests/mocks',
    ignore: ['jquery', 'underscore', 'backbone'],
    whitelist: ['tests/unit']
});

我在运行此代码后看到的问题是我正在测试的模块(base.js)也被模拟出来以及单元测试模块,因为它们作为依赖项包含在单元测试运行器中:

define([
  'tests/unit/test-unit',
  'tests/unit/views/base-view-unit',
], function(Test, BaseViewTest){

// ...

});

控制台输出:

http://localhost:63342/project/tests/mocks/js/views/base.stub.js 404 (Not Found)
http://localhost:63342/project/tests/mocks/tests/unit/views/base-view-unit.stub.js 404 (Not Found)

我可以将这两个文件添加到白名单中,但这不能解决我的问题。

我想我的问题是:如何模拟我正在测试的文件的deps而不是文件本身,当它被包含在单元测试运行器中时?

1 个答案:

答案 0 :(得分:0)

好的,我在this post中找到了可能的答案,说我需要使用单独的config.js来加载来自不同路径的模拟依赖项。育。