diff options
author | Klaus Hartl <klaus.hartl@googlemail.com> | 2008-10-02 14:20:35 +0000 |
---|---|---|
committer | Klaus Hartl <klaus.hartl@googlemail.com> | 2008-10-02 14:20:35 +0000 |
commit | c2b0afd3e7dce76f01fa6661993cbf08105d22cb (patch) | |
tree | 1b4b2d1f03f50f3a91e0791830e8bb3b1500f146 /tests/tabs.js | |
parent | de7d22a02e72646d159f161ebfa07b6abadddbc8 (diff) | |
download | jquery-ui-c2b0afd3e7dce76f01fa6661993cbf08105d22cb.tar.gz jquery-ui-c2b0afd3e7dce76f01fa6661993cbf08105d22cb.zip |
UI Tabs: fixed "colon in id bug", wrote more unit tests and refactored stuff afterwards
Diffstat (limited to 'tests/tabs.js')
-rw-r--r-- | tests/tabs.js | 139 |
1 files changed, 135 insertions, 4 deletions
diff --git a/tests/tabs.js b/tests/tabs.js index 653b04f6f..51f582231 100644 --- a/tests/tabs.js +++ b/tests/tabs.js @@ -8,14 +8,145 @@ // Tabs Tests -module("tabs"); +module('tabs'); -test("init", function() { - expect(1); +test('init', function() { + expect(4); - el = $("#tabs1").tabs(); + var el = $('#tabs1 > ul').tabs(); ok(true, '.tabs() called on element'); + + el.tabs('destroy').tabs({ selected: 1 }); + equals( el.data('selected.tabs'), 1 ); + equals( $('li', el).index( $('li.ui-tabs-selected', el) ), 1, 'second tab active'); + equals( $('div', '#tabs1').index( $('div.ui-tabs-hide', '#tabs1') ), 0, 'first panel should be hidden' ); + }); +test('destroy', function() { + expect(0); + +}); + +test("defaults", function() { + + var expected = { + unselect: false, + event: 'click', + disabled: [], + cookie: null, + spinner: 'Loading…', + cache: false, + idPrefix: 'ui-tabs-', + ajaxOptions: null, + fx: null, + tabTemplate: '<li><a href="#{href}"><span>#{label}</span></a></li>', + panelTemplate: '<div></div>', + navClass: 'ui-tabs-nav', + selectedClass: 'ui-tabs-selected', + unselectClass: 'ui-tabs-unselect', + disabledClass: 'ui-tabs-disabled', + panelClass: 'ui-tabs-panel', + hideClass: 'ui-tabs-hide', + loadingClass: 'ui-tabs-loading' + }; + + var el = $("#tabs1").tabs(); + + for (var optionName in expected) { + var actual = el.data(optionName + '.tabs'), expects = expected[optionName]; + + if (optionName == 'disabled') + ok(expects.constructor == Array && !expects.length, optionName); + else + equals(actual, expects, optionName); + + } + +}); + +test('add', function() { + expect(0); + +}); + +test('remove', function() { + expect(0); + +}); + +test('enable', function() { + expect(0); + +}); + +test('disable', function() { + expect(0); + +}); + +test('select', function() { + expect(0); + +}); + +test('load', function() { + expect(0); + +}); + +test('url', function() { + expect(0); + +}); + +test('cookie', function() { + expect(5); + + var el = $('#tabs1 > ul'); + var cookieName = 'ui-tabs-' + $.data(el[0]); + $.cookie(cookieName, null); // blank state + var cookie = function() { + return parseInt($.cookie(cookieName), 10); + }; + + el.tabs({ cookie: {} }); + equals(cookie(), 0, 'initial cookie value, no cookie given'); + + el.tabs('destroy'); + el.tabs({ selected: 1, cookie: {} }); + equals(cookie(), 1, 'initial cookie value, given selected'); + + el.tabs('select', 2); + equals(cookie(), 2, 'cookie value after tabs select'); + + el.tabs('destroy'); + $.cookie(cookieName, 1); + el.tabs({ cookie: {} }); + equals(cookie(), 1, 'initial cookie value, from existing cookie'); + + el.tabs('destroy'); + ok($.cookie(cookieName) === null, 'erase cookie after destroy'); + +}); + +// #??? +test('id containing colon', function() { + expect(4); + + var el = $('#tabs2 > ul').tabs(); + ok( $('div.ui-tabs-panel:eq(0)', '#tabs2').is(':visible'), 'first panel should be visible' ); + ok( $('div.ui-tabs-panel:eq(1)', '#tabs2').is(':hidden'), 'second panel should be hidden' ); + + el.tabs('select', 1).tabs('select', 0); + ok( $('div.ui-tabs-panel:eq(0)', '#tabs2').is(':visible'), 'first panel should be visible' ); + ok( $('div.ui-tabs-panel:eq(1)', '#tabs2').is(':hidden'), 'second panel should be hidden' ); + +}); + +// test('', function() { +// expect(0); +// +// }); })(jQuery); |