'use strict'; describe('ngSwitch', function() { var element; afterEach(function(){ dealoc(element); }); it('should switch on value change', inject(function($rootScope, $compile) { element = $compile( '
' + '
first:{{name}}
' + '
second:{{name}}
' + '
true:{{name}}
' + '
')($rootScope); expect(element.html()).toEqual( ''); $rootScope.select = 1; $rootScope.$apply(); expect(element.text()).toEqual('first:'); $rootScope.name="shyam"; $rootScope.$apply(); expect(element.text()).toEqual('first:shyam'); $rootScope.select = 2; $rootScope.$apply(); expect(element.text()).toEqual('second:shyam'); $rootScope.name = 'misko'; $rootScope.$apply(); expect(element.text()).toEqual('second:misko'); $rootScope.select = true; $rootScope.$apply(); expect(element.text()).toEqual('true:misko'); })); it('should show all switch-whens that match the current value', inject(function($rootScope, $compile) { element = $compile( '')($rootScope); expect(element.html()).toEqual('' + '' + '' + ''); $rootScope.select = 1; $rootScope.$apply(); expect(element.text()).toEqual('first:, first too:'); $rootScope.name="shyam"; $rootScope.$apply(); expect(element.text()).toEqual('first:shyam, first too:shyam'); $rootScope.select = 2; $rootScope.$apply(); expect(element.text()).toEqual('second:shyam'); $rootScope.name = 'misko'; $rootScope.$apply(); expect(element.text()).toEqual('second:misko'); $rootScope.select = true; $rootScope.$apply(); expect(element.text()).toEqual('true:misko'); })); it('should switch on switch-when-default', inject(function($rootScope, $compile) { element = $compile( '' + '
one
' + '
other
' + '
')($rootScope); $rootScope.$apply(); expect(element.text()).toEqual('other'); $rootScope.select = 1; $rootScope.$apply(); expect(element.text()).toEqual('one'); })); it('should show all switch-when-default', inject(function($rootScope, $compile) { element = $compile( '')($rootScope); $rootScope.$apply(); expect(element.text()).toEqual('other, other too'); $rootScope.select = 1; $rootScope.$apply(); expect(element.text()).toEqual('one'); })); it('should always display the elements that do not match a switch', inject(function($rootScope, $compile) { element = $compile( '')($rootScope); $rootScope.$apply(); expect(element.text()).toEqual('always other, other too '); $rootScope.select = 1; $rootScope.$apply(); expect(element.text()).toEqual('always one '); })); it('should display the elements that do not have ngSwitchWhen nor ' + 'ngSwitchDefault at the position specified in the template, when the ' + 'first and last elements in the ngSwitch body do not have a ngSwitch* ' + 'directive', inject(function($rootScope, $compile) { element = $compile( '')($rootScope); $rootScope.$apply(); expect(element.text()).toEqual('135678'); $rootScope.select = 1; $rootScope.$apply(); expect(element.text()).toEqual('12368'); })); it('should display the elements that do not have ngSwitchWhen nor ' + 'ngSwitchDefault at the position specified in the template when the ' + 'first and last elements in the ngSwitch have a ngSwitch* directive', inject(function($rootScope, $compile) { element = $compile( '')($rootScope); $rootScope.$apply(); expect(element.text()).toEqual('3567'); $rootScope.select = 1; $rootScope.$apply(); expect(element.text()).toEqual('236'); })); it('should call change on switch', inject(function($rootScope, $compile) { element = $compile( '' + '
{{name}}
' + '
')($rootScope); $rootScope.url = 'a'; $rootScope.$apply(); expect($rootScope.name).toEqual('works'); expect(element.text()).toEqual('works'); })); it('should properly create and destroy child scopes', inject(function($rootScope, $compile) { element = $compile( '' + '
{{name}}
' + '
')($rootScope); $rootScope.$apply(); var getChildScope = function() { return element.find('div').scope(); }; expect(getChildScope()).toBeUndefined(); $rootScope.url = 'a'; $rootScope.$apply(); var child1 = getChildScope(); expect(child1).toBeDefined(); spyOn(child1, '$destroy'); $rootScope.url = 'x'; $rootScope.$apply(); expect(getChildScope()).toBeUndefined(); expect(child1.$destroy).toHaveBeenCalledOnce(); $rootScope.url = 'a'; $rootScope.$apply(); var child2 = getChildScope(); expect(child2).toBeDefined(); expect(child2).not.toBe(child1); })); it('should not leak jq data when compiled but not attached to parent when parent is destroyed', inject(function($rootScope, $compile) { element = $compile( '
' + '' + '
{{name}}
' + '
' + '
')($rootScope); $rootScope.$apply(); // element now contains only empty repeater. this element is dealocated by local afterEach. // afterwards a global afterEach will check for leaks in jq data cache object })); });