我正在尝试为我的指令进行单元测试。
我有类似
的东西'use strict';
describe('directive test', function () {
var $compile, $rootScope, httpBackend, ngFactory;
beforeEach(module('myApp'));
beforeEach(inject(function (_$compile_, _$rootScope_, _$httpBackend_, _ngFactory_) {
$compile = _$compile_;
scope = _$rootScope_.$new();
$httpBackend = _$httpBackend_;
ngFactory = _ngFactory_;
$httpBackend.whenGET('template.html').respond(200);
}));
it('this will setup directive', function() {
var elem = $compile('<my-factory factoryName="name1"></my-factory>')(scope);
scope.$digest();
expect(scope.run).toBe(1);
});
});
我的指示
(function(window, angular) {
'use strict';
var app = angular.module('myApp');
app.directive('myFactory', ['ngFactory',
function(ngFactory) {
return {
restrict: 'E',
templateUrl:'template.html',
link: function(scope, elem, attrs) { //not cover
scope.test = function() { //not cover
//do stuff here //not cover
}; //not cover
} //not cover
};
}
]);
})(window, angular);
出于某种原因,我的单元测试并未涵盖链接功能。我不确定我做错了什么。有人可以帮帮我吗?谢谢!
答案 0 :(得分:1)
您还需要刷新模板请求:
it('this will setup directive', function() {
var elem = $compile('<my-factory factoryName="name1"></my-factory>')(scope);
$httpBackend.flush();
scope.$digest();
expect(scope.run).toBe(1);
});
确保加载并呈现正确的模板。