151 行
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			151 行
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
$(function () {
 | 
						|
 | 
						|
  module("bootstrap-modal")
 | 
						|
 | 
						|
    test("should be defined on jquery object", function () {
 | 
						|
      var div = $("<div id='modal-test'></div>")
 | 
						|
      ok(div.modal, 'modal method is defined')
 | 
						|
    })
 | 
						|
 | 
						|
    test("should return element", function () {
 | 
						|
      var div = $("<div id='modal-test'></div>")
 | 
						|
      ok(div.modal() == div, 'div element returned')
 | 
						|
    })
 | 
						|
 | 
						|
    test("should expose defaults var for settings", function () {
 | 
						|
      ok($.fn.modal.defaults, 'default object exposed')
 | 
						|
    })
 | 
						|
 | 
						|
    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")
 | 
						|
    })
 | 
						|
 | 
						|
    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")
 | 
						|
     })
 | 
						|
 | 
						|
     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")
 | 
						|
     })
 | 
						|
 | 
						|
     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")
 | 
						|
     })
 | 
						|
 | 
						|
     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")
 | 
						|
     })
 | 
						|
 | 
						|
     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")
 | 
						|
     })
 | 
						|
 | 
						|
     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")
 | 
						|
     })
 | 
						|
 | 
						|
     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")
 | 
						|
     })
 | 
						|
})
 |