diff options
author | Scott González <scott.gonzalez@gmail.com> | 2011-04-28 14:38:57 -0400 |
---|---|---|
committer | Scott González <scott.gonzalez@gmail.com> | 2011-04-28 14:38:57 -0400 |
commit | 09faa7c9fa6d16313485d727e3943303c0181ebf (patch) | |
tree | d777b12906dd4b40cd18dca183bd1ed8acc7b7e9 /tests | |
parent | 5d23e8eacd95b0bcb859c4303a39709ef8a4dc86 (diff) | |
download | jquery-ui-09faa7c9fa6d16313485d727e3943303c0181ebf.tar.gz jquery-ui-09faa7c9fa6d16313485d727e3943303c0181ebf.zip |
Tabs: Added more tests for refresh method and changed the implementation a bit.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/unit/tabs/tabs_methods.js | 116 |
1 files changed, 67 insertions, 49 deletions
diff --git a/tests/unit/tabs/tabs_methods.js b/tests/unit/tabs/tabs_methods.js index 9d6864218..361ace45b 100644 --- a/tests/unit/tabs/tabs_methods.js +++ b/tests/unit/tabs/tabs_methods.js @@ -85,55 +85,73 @@ test( "disable( index )", function() { tabs_disabled( element, true ); }); -test('refresh', function() { - expect( 13 ); - - var el = $('<div id="tabs"><ul></ul></div>').tabs(), - ul = el.find('ul'); - - equals(el.tabs('option', 'active'), false, 'Initially empty, no active tab'); - - ul.append('<li><a href="data/test.html">Test 1</a></li>'); - el.tabs('refresh'); - equals( el.tabs('option', 'active'), 0, 'First tab added should be auto active'); - ok( $( "li:eq(0)", el).is('.ui-tabs-active'), 'First tab should be auto active'); - equals( el.find('.ui-tabs-panel').length, 1, 'Panel created after refresh'); - - ul.find('li').remove(); - el.tabs('refresh'); - equals( el.find('.ui-tabs-panel').length, 0, 'Panel removed after refresh'); - equals( el.tabs('option', 'active'), false, 'No tabs are active'); - - // Hide second tab - $('<li><a href="#test1">Test 1</a></li><li><a href="#test2">Test 2</a></li><li><a href="#test3">Test 3</a></li>') - .appendTo( ul ); - $('<div id="test1">Test Panel 1</div><div id="test2">Test Panel 2</div><div id="test3">Test Panel 3</div>') - .insertAfter( ul ); - el.tabs('refresh'); - equals( el.tabs('option', 'active'), 0, 'Second tab added should not be auto active'); - equals( $( "#test2", el ).css("display"), "none", 'Second panel is hidden'); - - // Make second tab active and then remove the first one - el.tabs('option', 'active', 1); - el.find('a[href="#test1"]').parent().remove(); - el.tabs('refresh'); - equals( el.tabs('option', 'active'), 0, 'Active index correctly updated'); - ok( el.find('a[href="#test2"]').parent().is('.ui-tabs-active'), 'Tab is still active'); - - // Refresh with disabled tabs - el.tabs('disable', 1); - same( el.tabs('option', 'disabled'), [ 1 ], 'Second tab disabled'); - - el.find('a[href="#test3"]').remove(); - ul.append('<li><a href="#test4">Test 4</a></li>'); - $('<div id="test4">Test Panel 4</div>').insertAfter( ul ); - el.tabs('refresh'); - equals( el.tabs('option', 'disabled'), false, 'Not disabled'); - - ul.append('<li class="ui-state-disabled"><a href="#test3">Test 3</a></li>'); - $('<div id="test3">Test Panel 3</div>').insertAfter( ul ); - el.tabs('refresh'); - same( el.tabs('option', 'disabled'), [ 2 ], 'Second tab disabled'); +test( "refersh", function() { + expect( 27 ); + + var element = $( "#tabs1" ).tabs(); + tabs_state( element, 1, 0, 0 ); + tabs_disabled( element, false ); + + // disable tab via markup + element.find( ".ui-tabs-nav li" ).eq( 1 ).addClass( "ui-state-disabled" ); + element.tabs( "refresh" ); + tabs_state( element, 1, 0, 0 ); + tabs_disabled( element, [ 1 ] ); + + // add remote tab + element.find( ".ui-tabs-nav" ).append( "<li id='newTab'><a href='data/test.html'>new</a></li>" ); + element.tabs( "refresh" ); + tabs_state( element, 1, 0, 0, 0 ); + tabs_disabled( element, [ 1 ] ); + equals( element.find( "#" + $( "#newTab a" ).attr( "aria-controls" ) ).length, 1, + "panel added for remote tab" ); + + // remove all tabs + element.find( ".ui-tabs-nav li, .ui-tabs-panel" ).remove(); + element.tabs( "refresh" ); + tabs_state( element ); + equals( element.tabs( "option", "active" ), false, "no active tab" ); + + // add tabs + element.find( ".ui-tabs-nav" ) + .append( "<li class='ui-state-disabled'><a href='#newTab2'>new 2</a></li>" ) + .append( "<li><a href='#newTab3'>new 3</a></li>" ) + .append( "<li><a href='#newTab4'>new 4</a></li>" ) + .append( "<li><a href='#newTab5'>new 5</a></li>" ); + element + .append( "<div id='newTab2'>new 2</div>" ) + .append( "<div id='newTab3'>new 3</div>" ) + .append( "<div id='newTab4'>new 4</div>" ) + .append( "<div id='newTab5'>new 5</div>" ); + element.tabs( "refresh" ); + tabs_state( element, 0, 0, 0, 0 ); + tabs_disabled( element, [ 0 ] ); + + // activate third tab + element.tabs( "option", "active", 2 ); + tabs_state( element, 0, 0, 1, 0 ); + tabs_disabled( element, [ 0 ] ); + + // remove fourth tab, third tab should stay active + element.find( ".ui-tabs-nav li" ).eq( 3 ).remove(); + element.find( ".ui-tabs-panel" ).eq( 3 ).remove(); + element.tabs( "refresh" ); + tabs_state( element, 0, 0, 1 ); + tabs_disabled( element, [ 0 ] ); + + // remove third (active) tab, second tab should become active + element.find( ".ui-tabs-nav li" ).eq( 2 ).remove(); + element.find( ".ui-tabs-panel" ).eq( 2 ).remove(); + element.tabs( "refresh" ); + tabs_state( element, 0, 1 ); + tabs_disabled( element, [ 0 ] ); + + // remove first tab, previously active tab (now first) should stay active + element.find( ".ui-tabs-nav li" ).eq( 0 ).remove(); + element.find( ".ui-tabs-panel" ).eq( 0 ).remove(); + element.tabs( "refresh" ); + tabs_state( element, 1 ); + tabs_disabled( element, false ); }); test('load', function() { |