我正在编写一个规范来检查在测试的Angular模块的配置阶段调用方法.
这是对正在测试的代码的简化看法:
angular.module('core',['services.configAction']) .config(function(configAction){ configAction.deferIntercept(true); });
上面发生的是我们定义一个具有单一依赖关系的核心模块.
然后,在核心模块的config-block中,我们在configAction对象上调用deferIntercept方法,该方法由services.configAction使用.
这是当前的设置:
describe('core',function() { const configActionProvider={ deferIntercept:jasmine.createSpy('deferIntercept'),$get:function(){ return {/*...*/} } }; beforeEach(function() { module(function($provide) { $provide.provider('configAction',configActionProvider); }); module('core.AppInitializer'); inject(function($injector) { //... }); }); it('should call deferIntercept',function() { expect(configActionProvider.deferIntercept).toHaveBeenCalledWith(true); }); });
问题是它不会覆盖configAction,所以从不调用spy,原始方法是.
如果我将它作为核心模块的依赖项删除它将会这样做,因此angular.module(‘core’,[])而不是angular.module(‘core’,[‘services.configAction’])将起作用,间谍被称为.
知道如何在测试期间覆盖services.configAction而不从依赖列表中删除它吗?
解决方法
看看 –
https://dzone.com/articles/unit-testing-config-and-run.
像下面这样的东西 –
像下面这样的东西 –
module('services.configAction',function (configAction) { mockConfigAction = configAction; spyOn(mockConfigAction,'deferIntercept').andCallThrough(); }); module('core');
在你的beforeEach可能会完成这项工作.