angularjs – 如何模拟配置阶段提供程序进行单元测试?

前端之家收集整理的这篇文章主要介绍了angularjs – 如何模拟配置阶段提供程序进行单元测试?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在编写一个规范来检查在测试的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可能会完成这项工作.

猜你在找的Angularjs相关文章