test(ngRepeat): add a test for ngRepeat when using 'track by' and a filter

This commit is contained in:
Brian Ford 2013-07-18 14:22:04 -07:00
parent ef4458a798
commit 715d97d5c8

View file

@ -125,6 +125,54 @@ describe('ngRepeat', function() {
});
it('should still filter when track is present', function() {
scope.isIgor = function (item) {
return item.name === 'igor';
};
element = $compile(
'<ul>' +
'<li ng-repeat="item in items | filter:isIgor track by $id(item)">{{item.name}};</li>' +
'</ul>')(scope);
scope.items = [{name: 'igor'}, {name: 'misko'}];
scope.$digest();
expect(element.find('li').text()).toBe('igor;');
});
it('should track using provided function when a filter is present', function() {
scope.newArray = function (items) {
var newArray = [];
angular.forEach(items, function (item) {
newArray.push({
id: item.id,
name: item.name
});
});
return newArray;
};
element = $compile(
'<ul>' +
'<li ng-repeat="item in items | filter:newArray track by item.id">{{item.name}};</li>' +
'</ul>')(scope);
scope.items = [
{id: 1, name: 'igor'},
{id: 2, name: 'misko'}
];
scope.$digest();
expect(element.text()).toBe('igor;misko;');
var li0 = element.find('li')[0];
var li1 = element.find('li')[1];
scope.items.push(scope.items.shift());
scope.$digest();
expect(element.find('li')[0]).toBe(li1);
expect(element.find('li')[1]).toBe(li0);
});
it('should iterate over an array of primitives', function() {
element = $compile(
'<ul>' +