5 test("should provide no conflict", function () {
6 var collapse = $.fn.collapse.noConflict()
7 ok(!$.fn.collapse, 'collapse was set back to undefined (org value)')
8 $.fn.collapse = collapse
11 test("should be defined on jquery object", function () {
12 ok($(document.body).collapse, 'collapse method is defined')
15 test("should return element", function () {
16 ok($(document.body).collapse()[0] == document.body, 'document.body returned')
19 test("should show a collapsed element", function () {
20 var el = $('<div class="collapse"></div>').collapse('show')
21 ok(el.hasClass('in'), 'has class in')
22 ok(/height/.test(el.attr('style')), 'has height set')
25 test("should hide a collapsed element", function () {
26 var el = $('<div class="collapse"></div>').collapse('hide')
27 ok(!el.hasClass('in'), 'does not have class in')
28 ok(/height/.test(el.attr('style')), 'has height set')
31 test("should not fire shown when show is prevented", function () {
32 $.support.transition = false
34 $('<div class="collapse"/>')
35 .on('show.bs.collapse', function (e) {
40 .on('shown.bs.collapse', function () {
46 test("should reset style to auto after finishing opening collapse", function () {
47 $.support.transition = false
49 $('<div class="collapse" style="height: 0px"/>')
50 .on('show.bs.collapse', function () {
51 ok(this.style.height == '0px')
53 .on('shown.bs.collapse', function () {
54 ok(this.style.height == 'auto')
60 test("should add active class to target when collapse shown", function () {
61 $.support.transition = false
64 var target = $('<a data-toggle="collapse" href="#test1"></a>')
65 .appendTo($('#qunit-fixture'))
67 var collapsible = $('<div id="test1"></div>')
68 .appendTo($('#qunit-fixture'))
69 .on('show.bs.collapse', function () {
70 ok(!target.hasClass('collapsed'))
77 test("should remove active class to target when collapse hidden", function () {
78 $.support.transition = false
81 var target = $('<a data-toggle="collapse" href="#test1"></a>')
82 .appendTo($('#qunit-fixture'))
84 var collapsible = $('<div id="test1" class="in"></div>')
85 .appendTo($('#qunit-fixture'))
86 .on('hide.bs.collapse', function () {
87 ok(target.hasClass('collapsed'))
94 test("should remove active class from inactive accordion targets", function () {
95 $.support.transition = false
98 var accordion = $('<div id="accordion"><div class="accordion-group"></div><div class="accordion-group"></div><div class="accordion-group"></div></div>')
99 .appendTo($('#qunit-fixture'))
101 var target1 = $('<a data-toggle="collapse" href="#body1" data-parent="#accordion"></a>')
102 .appendTo(accordion.find('.accordion-group').eq(0))
104 var collapsible1 = $('<div id="body1" class="in"></div>')
105 .appendTo(accordion.find('.accordion-group').eq(0))
107 var target2 = $('<a class="collapsed" data-toggle="collapse" href="#body2" data-parent="#accordion"></a>')
108 .appendTo(accordion.find('.accordion-group').eq(1))
110 var collapsible2 = $('<div id="body2"></div>')
111 .appendTo(accordion.find('.accordion-group').eq(1))
113 var target3 = $('<a class="collapsed" data-toggle="collapse" href="#body3" data-parent="#accordion"></a>')
114 .appendTo(accordion.find('.accordion-group').eq(2))
116 var collapsible3 = $('<div id="body3"></div>')
117 .appendTo(accordion.find('.accordion-group').eq(2))
118 .on('show.bs.collapse', function () {
119 ok(target1.hasClass('collapsed'))
120 ok(target2.hasClass('collapsed'))
121 ok(!target3.hasClass('collapsed'))
129 test("should allow dots in data-parent", function () {
130 $.support.transition = false
133 var accordion = $('<div class="accordion"><div class="accordion-group"></div><div class="accordion-group"></div><div class="accordion-group"></div></div>')
134 .appendTo($('#qunit-fixture'))
136 var target1 = $('<a data-toggle="collapse" href="#body1" data-parent=".accordion"></a>')
137 .appendTo(accordion.find('.accordion-group').eq(0))
139 var collapsible1 = $('<div id="body1" class="in"></div>')
140 .appendTo(accordion.find('.accordion-group').eq(0))
142 var target2 = $('<a class="collapsed" data-toggle="collapse" href="#body2" data-parent=".accordion"></a>')
143 .appendTo(accordion.find('.accordion-group').eq(1))
145 var collapsible2 = $('<div id="body2"></div>')
146 .appendTo(accordion.find('.accordion-group').eq(1))
148 var target3 = $('<a class="collapsed" data-toggle="collapse" href="#body3" data-parent=".accordion"></a>')
149 .appendTo(accordion.find('.accordion-group').eq(2))
151 var collapsible3 = $('<div id="body3"></div>')
152 .appendTo(accordion.find('.accordion-group').eq(2))
153 .on('show.bs.collapse', function () {
154 ok(target1.hasClass('collapsed'))
155 ok(target2.hasClass('collapsed'))
156 ok(!target3.hasClass('collapsed'))