加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – 如何模拟提供者

发布时间:2020-12-17 07:17:37 所属栏目:安全 来源:网络整理
导读:我的Angular 1.3应用程序正在使用 angular-translate library.在我的Karma测试中,我试图使用我创建的Mock对象来模拟$translate提供程序. 模拟对象称为MockTranslate,它属于myMocks模块.我没有在问题中包含MockTranslate的来源,因为它与问题无关. 我测试的主
我的Angular 1.3应用程序正在使用 angular-translate library.在我的Karma测试中,我试图使用我创建的Mock对象来模拟$translate提供程序.

模拟对象称为MockTranslate,它属于myMocks模块.我没有在问题中包含MockTranslate的来源,因为它与问题无关.

我测试的主题是一个控制器,我可以很容易地使用以下方法模拟$translate:

module('myMocks');
inject(function($controller,MockTranslate) {                                                                                              
  $controller("MyController",{                                                                                                           
    $translate: MockTranslate.create(translations);                                                                                        
  });                                                                                                                                      
});

上面的模拟工作,但我更喜欢使用angular.mock.module模拟提供程序,如下所示:

module('myMocks');
module("myModule",function($provide) {                                                                                                    
  $provide.provider("$translate",function(MockTranslate) {                                                                              
    return MockTranslate.create(translations);                                                                                      
  });                                                                                                                                      
});

但是当我运行测试时出现以下错误:

错误:[$injector:modulerr]由于以下原因无法实例化模块函数($provide):错误:[$injector:unpr]未知提供者:MockTranslate

如何使用angular.mock.module模拟提供程序?

如果我正确地理解了这个任务,那么这是一个有效的例子:
angular.module('translateApp',[])
    .controller('translateCtrl',function ($scope,$translate) {
        $scope.translate = function(message) {
            return $translate.translate(message);
        };
    })
    .provider({
        $translate: function() {
            this.$get = function () {
                return {
                    translate: function (msg) {
                        return 'OriginalTranslate: ' + msg;
                    }
                };
            };
        }
    });

describe('Translate Controller Test',function() {
    var mockScope;
    var mockTranslate;

    beforeEach(module('translateApp',function($provide) {
        $provide.provider('MockTranslate',function() {
            this.$get = function () {
                return {
                    translate: function (msg) {
                        return 'MockTranslate: ' + msg;
                    }
                };
            }
        });

        $provide.provider('$translate',function() {
            this.$get = function (MockTranslate) {
                return {
                    translate: function (msg) {
                        return MockTranslate.translate(msg);
                    }
                };
            }
        });
    }));

    beforeEach(inject(function($controller,$rootScope,$translate) {
        mockScope = $rootScope.$new();
        mockTranslate = $translate;

        $controller('translateCtrl',{
            $scope: mockScope,$translate: mockTranslate
        });
    }));

    it('Translates messages',function () {
        expect(mockScope.translate('cool message')).toEqual('MockTranslate: cool message');
    });
});

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读