bootstrap-modal.js 4.62 KB
Newer Older
1
2
$(function () {

3
  module("bootstrap-modal")
4

5
6
7
8
    test("should be defined on jquery object", function () {
      var div = $("<div id='modal-test'></div>")
      ok(div.modal, 'modal method is defined')
    })
9

10
11
12
13
    test("should return element", function () {
      var div = $("<div id='modal-test'></div>")
      ok(div.modal() == div, 'div element returned')
    })
14

15
16
17
    test("should expose defaults var for settings", function () {
      ok($.fn.modal.defaults, 'default object exposed')
    })
18

19
20
21
22
23
24
25
26
27
28
29
30
31
    test("should insert into dom when show method is called", function () {
      stop()
      $.support.transition = false
      var div = $("<div id='modal-test'></div>")
      div
        .modal()
        .bind("shown", function () {
          ok($('#modal-test').length, 'modal insterted into dom')
          start()
          div.remove()
        })
        .modal("show")
    })
32

33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
    test("should hide modal when hide is called", function () {
       stop()
       $.support.transition = false
       var div = $("<div id='modal-test'></div>")
       div
         .modal()
         .bind("shown", function () {
           ok($('#modal-test').is(":visible"), 'modal visible')
           ok($('#modal-test').length, 'modal insterted into dom')
           div.modal("hide")
         })
         .bind("hidden", function() {
           ok(!$('#modal-test').is(":visible"), 'modal hidden')
           start()
           div.remove()
         })
         .modal("show")
     })
51

52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
     test("should toggle when toggle is called", function () {
       stop()
       $.support.transition = false
       var div = $("<div id='modal-test'></div>")
       div
         .modal()
         .bind("shown", function () {
           ok($('#modal-test').is(":visible"), 'modal visible')
           ok($('#modal-test').length, 'modal insterted into dom')
           div.modal("toggle")
         })
         .bind("hidden", function() {
           ok(!$('#modal-test').is(":visible"), 'modal hidden')
           start()
           div.remove()
         })
         .modal("toggle")
     })
70

71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
     test("should remove from dom when click .close", function () {
       stop()
       $.support.transition = false
       var div = $("<div id='modal-test'><span class='close'></span></div>")
       div
         .modal()
         .bind("shown", function () {
           ok($('#modal-test').is(":visible"), 'modal visible')
           ok($('#modal-test').length, 'modal insterted into dom')
           div.find('.close').click()
         })
         .bind("hidden", function() {
           ok(!$('#modal-test').is(":visible"), 'modal hidden')
           start()
           div.remove()
         })
         .modal("toggle")
     })
89

90
91
92
93
94
95
96
97
98
99
100
101
102
103
     test("should add backdrop when desired", function () {
       stop()
       $.support.transition = false
       var div = $("<div id='modal-test'></div>")
       div
         .modal({ backdrop:true })
         .bind("shown", function () {
           equal($('.modal-backdrop').length, 1, 'modal backdrop inserted into dom')
           start()
           div.remove()
           $('.modal-backdrop').remove()
         })
        .modal("show")
     })
104

105
106
107
108
109
110
111
112
113
114
115
116
117
     test("should not add backdrop when not desired", function () {
       stop()
       $.support.transition = false
       var div = $("<div id='modal-test'></div>")
       div
         .modal({backdrop:false})
         .bind("shown", function () {
           equal($('.modal-backdrop').length, 0, 'modal backdrop not inserted into dom')
           start()
           div.remove()
         })
         .modal("show")
     })
118

119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
     test("should close backdrop when clicked", function () {
       stop()
       $.support.transition = false
       var div = $("<div id='modal-test'></div>")
       div
         .modal({backdrop:true})
         .bind("shown", function () {
           equal($('.modal-backdrop').length, 1, 'modal backdrop inserted into dom')
           $('.modal-backdrop').click()
           equal($('.modal-backdrop').length, 0, 'modal backdrop removed from dom')
           start()
           div.remove()
         })
         .modal("show")
     })
134

135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
     test("should not close backdrop when click disabled", function () {
       stop()
       $.support.transition = false
       var div = $("<div id='modal-test'></div>")
       div
         .modal({backdrop: 'static'})
         .bind("shown", function () {
           equal($('.modal-backdrop').length, 1, 'modal backdrop inserted into dom')
           $('.modal-backdrop').click()
           equal($('.modal-backdrop').length, 1, 'modal backdrop still in dom')
           start()
           div.remove()
           $('.modal-backdrop').remove()
         })
         .modal("show")
     })
151
})