单元测试自调用函数
Unit testing self-invoking functions
我在JavaScript文件中有一个自调用函数。像这样:
com.renderer = (function(){
render(data){
}
.....other functions
return{
init : function(){
$(document).ready(function(){
jsonData = fetchFromServer();
render(jsonData);
});
}
}
})().init();
我在想如何进行单元测试。我正在使用JSUnitTestDriver。如果我能以某种方式从外部注入jsonData
到渲染函数,那将是好的,但这对我来说似乎是不可能的。
有什么建议或替代方案吗?
我真的不想去掉函数的自调用特性。为了单元测试而改变我认为好的设计真的有意义吗?(在这种特殊情况下,不是一般情况)
注意:我不能在运行测试时与服务器通话。
问题是您正在尝试对单例进行单元测试,而单例通常不被认为是好的设计。
相反,我会考虑如下内容:
function createRenderer(dataFetcher) {
function render(data) {
}
// other functions
return {
init: function () {
$(document).ready(function () {
jsonData = dataFetcher();
render(jsonData);
});
}
};
}
// in your production code
com.renderer = createRenderer(fetchFromServer);
com.renderer.init();
// in your unit test
var renderer = createRenderer(function () {
return { test: "data" };
});
renderer.init();
// run your tests against renderer.
这使用了一种称为依赖注入的技术,其中对获取JSON数据的依赖被注入到您的渲染器中,分离出该责任。
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- HTML5(Bootstrap)通过函数调用运行动画
- 函数调用不起作用
- 函数中的Javascript函数调用