我已经问过这个question其中主要问题是作用域不存在于终端,但它存在于Chrome调试工具中。尽管答案没有得到解决。如何测试_.defer()使用茉莉花,AngularJs
问题是什么是正确的语法来测试波纹管指令,特别是行expect(scope.measurementScroll).toBe(true);
。虽然挖通过网络我找不到任何类似的问题,大多数问题都涉及到$q.defer()
凡在我的情况下,有下划线的方法_.defer()
控制器
'use strict';
angular.module('myApp')
.controller('MeasurementsTimelineCtrl', ['$scope', '$state', 'Measurements', function($scope, $state, Measurements) {
$scope.measurements = null;
var userId = $scope.currentUser ? $scope.currentUser.id : null;
if (userId) {
var listOfMeasurements = Measurements.userIndex(userId);
listOfMeasurements.then(function(data){
$scope.measurements = data;
$scope.$broadcast('measurements-updated', $scope.measurements);
});
}
}]);
指令:
'use strict';
angular.module('myApp')
.directive('dashboardMeasurementTimeline', ['$window', function($window) {
return {
restrict: 'E',
templateUrl: 'myView.html',
controller: 'MeasurementsTimelineCtrl',
link: function(scope, element){
scope.$on('measurements-updated', function(measurements) {
_.defer(function(){
if(measurements) {
scope.measurementScroll = true;
}
});
});
}
};
}]);
测试
'use strict';
describe('Directive: dashboardMeasurementTimeline', function() {
var $rootScope, $compile, element, scope;
beforeEach(function() {
module('myApp');
inject(function($injector) {
$rootScope = $injector.get('$rootScope');
$compile = $injector.get('$compile');
});
scope = $rootScope.$new();
element = angular.element('<dashboard-measurement-timeline></dashboard-measurement-timeline>');
element = $compile(element)(scope);
scope.currentUser = {id : 'someId'};
scope.$digest();
scope.measurements = [{id: 'someId', time_of_test: 'Tue, 30 Dec 2014 14:00:00 -0000'},
{id: 'someId', time_of_test: 'Thu, 20 Nov 2014 03:00:00 -0000'},];
scope.$broadcast('measurements-updated', scope.measurements);
scope.$apply();
});
it('should assign true value to measurementScroll', function() {
expect(scope.measurementScroll).toBe(true);
});
});
茉莉花1.3或2.0? – tasseKATT
我使用的插件是'karma-jasmine:0.1.5',而Google搜索发现它相当于Jasmine 2.0 – Max