Files
angular.js/test/ng/testabilitySpec.js
Julie Ralph 02aa4f4b85 fix(testability): escape regex chars in findBindings if using exactMatch
Move the function to escape regexps to Angular.js, fix the link, and use it in
the $$testability service.

Closes #9595
Closes #9600
2014-10-14 10:42:13 +01:00

199 lines
7.1 KiB
JavaScript

'use strict';
describe('$$testability', function() {
describe('finding elements', function() {
var $$testability, $compile, scope, element;
beforeEach(inject(function(_$$testability_, _$compile_, $rootScope) {
$$testability = _$$testability_;
$compile = _$compile_;
scope = $rootScope.$new();
}));
afterEach(function() {
dealoc(element);
});
it('should find partial bindings', function() {
element =
'<div>' +
' <span>{{name}}</span>' +
' <span>{{username}}</span>' +
'</div>';
element = $compile(element)(scope);
var names = $$testability.findBindings(element[0], 'name');
expect(names.length).toBe(2);
expect(names[0]).toBe(element.find('span')[0]);
expect(names[1]).toBe(element.find('span')[1]);
});
it('should find exact bindings', function() {
element =
'<div>' +
' <span>{{name}}</span>' +
' <span>{{username}}</span>' +
'</div>';
element = $compile(element)(scope);
var users = $$testability.findBindings(element[0], 'name', true);
expect(users.length).toBe(1);
expect(users[0]).toBe(element.find('span')[0]);
});
it('should ignore filters for exact bindings', function() {
element =
'<div>' +
' <span>{{name | uppercase}}</span>' +
' <span>{{username}}</span>' +
'</div>';
element = $compile(element)(scope);
var users = $$testability.findBindings(element[0], 'name', true);
expect(users.length).toBe(1);
expect(users[0]).toBe(element.find('span')[0]);
});
it('should ignore whitespace for exact bindings', function() {
element =
'<div>' +
' <span>{{ name }}</span>' +
' <span>{{username}}</span>' +
'</div>';
element = $compile(element)(scope);
var users = $$testability.findBindings(element[0], 'name', true);
expect(users.length).toBe(1);
expect(users[0]).toBe(element.find('span')[0]);
});
it('should find bindings by class', function() {
element =
'<div>' +
' <span ng-bind="name"></span>' +
' <span>{{username}}</span>' +
'</div>';
element = $compile(element)(scope);
var names = $$testability.findBindings(element[0], 'name');
expect(names.length).toBe(2);
expect(names[0]).toBe(element.find('span')[0]);
expect(names[1]).toBe(element.find('span')[1]);
});
it('should only search within the context element', function() {
element =
'<div>' +
' <ul><li>{{name}}</li></ul>' +
' <ul><li>{{name}}</li></ul>' +
'</div>';
element = $compile(element)(scope);
var names = $$testability.findBindings(element.find('ul')[0], 'name');
expect(names.length).toBe(1);
expect(names[0]).toBe(element.find('li')[0]);
});
it('should find bindings with allowed special characters', function() {
element =
'<div>' +
' <span>{{$index}}</span>' +
' <span>{{foo.bar}}</span>' +
' <span>{{foonbar}}</span>' +
' <span>{{foo | uppercase}}</span>' +
'</div>';
element = $compile(element)(scope);
var indexes = $$testability.findBindings(element[0], '$index', true);
expect(indexes.length).toBe(1);
expect(indexes[0]).toBe(element.find('span')[0]);
var foobars = $$testability.findBindings(element[0], 'foo.bar', true);
expect(foobars.length).toBe(1); // it should not match {{foonbar}}
expect(foobars[0]).toBe(element.find('span')[1]);
var foo = $$testability.findBindings(element[0], 'foo', true);
expect(foo.length).toBe(1); // it should match {{foo | uppercase}}
var uppercase = $$testability.findBindings(element[0], 'uppercase', true);
expect(uppercase.length).toBe(1); // it should match {{foo | uppercase}}
var filteredFoo = $$testability.findBindings(element[0], 'foo | uppercase', true);
expect(filteredFoo.length).toBe(1); // it should match {{foo | uppercase}}
expect(filteredFoo[0]).toBe(element.find('span')[3]);
});
it('should find partial models', function() {
element =
'<div>' +
' <input type="text" ng-model="name"/>' +
' <input type="text" ng-model="username"/>' +
'</div>';
element = $compile(element)(scope);
var names = $$testability.findModels(element[0], 'name');
expect(names.length).toBe(2);
expect(names[0]).toBe(element.find('input')[0]);
expect(names[1]).toBe(element.find('input')[1]);
});
it('should find exact models', function() {
element =
'<div>' +
' <input type="text" ng-model="name"/>' +
' <input type="text" ng-model="username"/>' +
'</div>';
element = $compile(element)(scope);
var users = $$testability.findModels(element[0], 'name', true);
expect(users.length).toBe(1);
expect(users[0]).toBe(element.find('input')[0]);
});
it('should find models in different input types', function() {
element =
'<div>' +
' <input type="text" ng-model="name"/>' +
' <textarea ng-model="username"/>' +
'</div>';
element = $compile(element)(scope);
var names = $$testability.findModels(element[0], 'name');
expect(names.length).toBe(2);
expect(names[0]).toBe(element.find('input')[0]);
expect(names[1]).toBe(element.find('textarea')[0]);
});
it('should only search for models within the context element', function() {
element =
'<div>' +
' <ul><li><input type="text" ng-model="name"/></li></ul>' +
' <ul><li><input type="text" ng-model="name"/></li></ul>' +
'</div>';
element = $compile(element)(scope);
var names = $$testability.findModels(element.find('ul')[0], 'name');
expect(names.length).toBe(1);
expect(names[0]).toBe(angular.element(element.find('li')[0]).find('input')[0]);
});
});
describe('location', function() {
beforeEach(module(function() {
return function($httpBackend) {
$httpBackend.when('GET', 'foo.html').respond('foo');
$httpBackend.when('GET', 'baz.html').respond('baz');
$httpBackend.when('GET', 'bar.html').respond('bar');
$httpBackend.when('GET', '404.html').respond('not found');
};
}));
it('should return the current URL', inject(function($location, $$testability) {
$location.path('/bar.html');
expect($$testability.getLocation()).toMatch(/bar.html$/);
}));
it('should change the URL', inject(function($location, $$testability) {
$location.path('/bar.html');
$$testability.setLocation('foo.html');
expect($location.path()).toEqual('/foo.html');
}));
});
describe('waiting for stability', function() {
it('should process callbacks immediately with no outstanding requests',
inject(function($$testability) {
var callback = jasmine.createSpy('callback');
$$testability.whenStable(callback);
expect(callback).toHaveBeenCalled();
}));
});
});