单元测试指令与链接使用控制器

时间:2017-01-22 14:42:07

标签: angularjs unit-testing angularjs-directive

我试图对我的指令进行单元测试,该指令根据控制器变量设置表单有效性。 我的指令代码:



angular.module('myModule',[])
        .directive('myDirective', function() {
    return {
        restrict: 'A',
        link: function(scope, element, attr, ctrl) {
            scope.$watch("mailExist", function(){
                if(scope.mailExist) {
                    ctrl.$setValidity('existingMailValidator', false);
                } else {
                    ctrl.$setValidity('existingMailValidator', true);
                }
            });
        }
    };
});




当尝试对此指令进行单元测试时,我试图用这段代码隔离控制器ctrl:



describe('directive module unit test implementation', function() {
    var $scope,
        ctrl,
        form;
   
    beforeEach(module('myModule'));
   
    beforeEach(inject(function($compile, $rootScope) {
        $scope = $rootScope;
        var element =angular.element(
            '<form name="testform">' +
                '<input name="testinput" user-mail-check>' +
            '</form>'
        ); 
        var ctrl = element.controller('userMailCheck');
        $compile(element)($scope);
        $scope.$digest();
        form = $scope.testform;
    }));
      
    describe('userMailCheck directive test', function() {
       it('should test initial state', function() {
           expect(form.testinput.$valid).toBe(true);
       }); 
    });
});
&#13;
&#13;
&#13;

运行此测试,我仍然获得:  无法阅读属性&#39; $ setValidity&#39;未定义的 这意味着我还没有真正注入控制器。 我的测试有什么问题?

1 个答案:

答案 0 :(得分:0)

最后找到解决方案: 首先在代码中添加:

require: 'ngModel',

然后修改单元测试如下:

describe('directive module unit test implementation', function() {
    var scope,
        ngModel,
        form;
   
    beforeEach(module('myModule'));
   
    beforeEach(inject(function($compile, $rootScope) {
        scope = $rootScope.$new();
        var element =angular.element(
            '<form name="testform">' +
                '<input name="testinput" ng-model="model" user-mail-check>' +
            '</form>'
        ); 
        var input = $compile(element)(scope);
        ngModel = input.controller('ngModel');
        scope.$digest();
        form = scope.testform;
    }));
      
    describe('userMailCheck directive test', function() {
       it('should test initial state', function() {
           expect(form.testinput.$valid).toBe(true);
       }); 
    });
});

并且一切都被罚款。