Как я могу проверить свою директиву?Единичное тестирование Директивы AngularJS
Что у меня есть
angular.module('MyModule').
directive('range', function() {
return {
restrict: 'E',
replace: true,
scope: {
bindLow: '=',
bindHigh: '=',
min: '@',
max: '@'
},
template: '<div><select ng-options="n for n in [min, max] | range" ng-model="bindLow"></select><select ng-options="n for n in [min, max] | range" ng-model="bindHigh"></select></div>'
};
})
В моем тестовом модуле я хочу начать с очень простого теста
describe('Range control', function() {
var elm, scope;
beforeEach(inject(function(_$compile_, _$rootScope) {
elm = angular.element('<range min="1" max="20" bind-low="low" bind-high="high"></range>');
var scope = _$rootScope_;
scope.low = 1;
scope.high = 20;
_$compile_(elm)(scope);
scope.$digest();
}));
it('should render two select elements', function() {
var selects = elm.find('select');
expect(selects.length).toBe(2);
});
});
Это не работает, хотя, как директива зарегистрирована на модуле приложения и я не хочу включать модуль, так как это сделает все мои коды config
и run
. Это нарушило бы цель проверки директивы как отдельной единицы.
Должен ли я поместить все мои директивы в отдельный модуль и загрузить именно это? Или есть ли другой умный способ решить это?
примечание: вы определили объем уага снова внутри beforeEach. также: _ $ rootScope vs _ $ rootScope _ – felix