模拟localForage.getItem方法的最佳方式是什么?当调用localForage.getItem时,我只需要简单地返回一个示例对象。
第一件事是将第三方库封装在可注入服务中,这样您就可以在测试中交换模拟实现
app.factory('localForage',function(){
//likely coming from global namesapce
return localForage;
});
然后可以将其注入指令、服务、控制器等中
//example with controller
myApp.controller('myCtrl',['localForage',function(localForage){
this.getItem = localForage.getItem;
this.setItem = loaclForage.setItem;
}]);
现在的想法是在测试中用mock来代替正常的实现。有几种方法:
-
全局:在运行测试之前创建一个mock模块将为所有测试,您将调用(beforeEach(module('myMockModule')),而不是实际的localForage模块
-
基于测试套件:在运行测试之前,"$提供"一个不同的实现:
beforeEach(module('myModule',function($provide){
$provide.factory('localForage', function(){
return MockImpl;
});
});
- 在某些情况下,您可以直接注入您的mock实现:
var ctrl;
beforeEach(inject(function($controller){
ctrl = $controller('myCtrl',{localForage:mockImpl});
}))
现在关于mock实现,它取决于你想用它做什么(监视它、存根等),但我们的想法是让它实现与实际服务相同的api
var mockImpl = {
getItem : angular.noop,
setItem : angular.noop
}
例如,如果您想检查是否调用了localForage以及使用哪些参数(使用spyOn(mockImpl,'getItem'))