测试:
'use strict';
describe('Directive: avatar', function () {
// load the directive's module
beforeEach(module('app'));
var element,
scope,
avatar_conf,
timeout,
mocked_avatar = '';
beforeEach(inject(function ($rootScope, _$timeout_, _avatar_conf_) {
scope = $rootScope.$new();
avatar_conf = _avatar_conf_;
timeout = _$timeout_;
}));
it('should set default alt property for an avatar that cannot be loaded', inject(function ($compile) {
element = angular.element('<img avatar src="mock.jpg">');
element = $compile(element)(scope);
scope.$digest();
expect(element.attr('alt')).toBe(avatar_conf.default_alt);
}));
代码:
!(function (window, angular) {
'use strict';
/**
* @ngdoc directive
* @name app.directive:social
* @description
* # social
*/
angular.module('app.directives')
.directive('avatar', function(avatar_conf) {
return {
restrict: 'A',
link: function(scope, element, attrs) {
element.bind('error', function() {
if(!scope.$$phase){
scope.$apply(function(){
attrs.$set('src', avatar_conf.default_image);
attrs.$set('alt', avatar_conf.default_alt);
});
}
});
}
};
});
}(window, window.angular));
问题:断言总是在链接器有机会更改attrs之前发生。 将断言置于超时0之内会导致它完全被调用(在加载DOM之后用于进行断言的hack)。
答案 0 :(得分:1)
解决方案是升级到Jasmine 2.0并定义异步测试:
升级Jasmine
,karma-jasmine
,and grunt-jasmine
$ npm install jasmine --save-dev
$ npm install karma-jasmine --save-dev
$ npm install grunt-jasmine --save-dev
试验:
it('should set default alt property for an avatar that cannot be loaded', function(done){
element = angular.element('<img avatar src="mock.jpg">');
element = $compile(element)(scope);
scope.$digest();
setTimeout(function(){
expect(element.attr('alt')).toBe(avatar_conf.default_alt);
done();
}, 200);
});