Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了unit-testing – 如何使用$location服务单元测试angularjs控制器大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图创建一个简单的单元测试,测试我的show函数

我得到以下错误

TypeError: Object #<Object> has no method 'show'

似乎$ rootScope不是控制器的范围?

这是我的控制器:

function OpponentsCtrl($scope,$LOCATIOn) {
    $scope.show = function(url) {
        $LOCATIOn.path(url);
    }
}
OpponentsCtrl.$inject = ['$scope','$LOCATIOn'];

这里是我的控制器单元测试:

describe('OpponentsCtrl',function() {
    beforeEach(module(function($providE) {
        $provide.factory('OpponentsCtrl',function($LOCATIOn){
            // whatever it does...
        });
    }));

    it('should change LOCATIOn when setTing it via show function',inject(function($LOCATIOn,$rootScope,OpponentsCtrl) {
        $LOCATIOn.path('/new/path');
        $rootScope.$apply();
        expect($LOCATIOn.path()).toBe('/new/path');

        $rootScope.show('/test');
        expect($LOCATIOn.path()).toBe('/test');
    }));
});
为什么不使用spyOn函数
describe('OpponentsCtrl',function() {

    var LOCATIOn;

    beforeEach(module(function($providE) {
        $provide.factory('OpponentsCtrl',function($LOCATIOn){
            LOCATIOn = $LOCATIOn;
        });
    }));

    it('should change LOCATIOn when setTing it via show function',inject(function() {    
        spyOn(LOCATIOn,'path');    
        expect(LOCATIOn.path).toHaveBeenCalledWith('/new/path');
    }));
});

希望这可以帮助!

大佬总结

以上是大佬教程为你收集整理的unit-testing – 如何使用$location服务单元测试angularjs控制器全部内容,希望文章能够帮你解决unit-testing – 如何使用$location服务单元测试angularjs控制器所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。