2011-12-20 18:02:47 -08:00
$ ( function ( ) {
2016-11-22 01:36:00 +11:00
'use strict'
2011-12-20 18:02:47 -08:00
2015-05-06 13:34:14 -07:00
QUnit . module ( 'button plugin' )
2014-02-13 09:55:12 +02:00
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should be defined on jquery object' , function ( assert ) {
assert . expect ( 1 )
assert . ok ( $ ( document . body ) . button , 'button method is defined' )
2014-02-13 09:55:12 +02:00
} )
2015-05-06 13:34:14 -07:00
QUnit . module ( 'button' , {
beforeEach : function ( ) {
2014-04-21 23:03:33 -06:00
// Run all tests in noConflict mode -- it's the only way to ensure that the plugin works in noConflict mode
$ . fn . bootstrapButton = $ . fn . button . noConflict ( )
} ,
2015-05-06 13:34:14 -07:00
afterEach : function ( ) {
2014-04-21 23:03:33 -06:00
$ . fn . button = $ . fn . bootstrapButton
delete $ . fn . bootstrapButton
2018-05-07 15:56:24 +02:00
$ ( '#qunit-fixture' ) . html ( '' )
2014-04-21 23:03:33 -06:00
}
} )
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should provide no conflict' , function ( assert ) {
assert . expect ( 1 )
2017-07-27 13:39:55 +03:00
assert . strictEqual ( typeof $ . fn . button , 'undefined' , 'button was set back to undefined (org value)' )
2014-04-21 23:03:33 -06:00
} )
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should return jquery collection containing the element' , function ( assert ) {
assert . expect ( 2 )
2014-06-18 21:33:38 +02:00
var $el = $ ( '<div/>' )
var $button = $el . bootstrapButton ( )
2015-05-06 13:34:14 -07:00
assert . ok ( $button instanceof $ , 'returns jquery collection' )
assert . strictEqual ( $button [ 0 ] , $el [ 0 ] , 'collection contains element' )
2014-02-13 09:55:12 +02:00
} )
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should toggle active' , function ( assert ) {
assert . expect ( 2 )
2014-10-17 15:17:57 +01:00
var $btn = $ ( '<button class="btn" data-toggle="button">mdo</button>' )
2015-05-06 13:34:14 -07:00
assert . ok ( ! $btn . hasClass ( 'active' ) , 'btn does not have active class' )
2014-06-18 21:33:38 +02:00
$btn . bootstrapButton ( 'toggle' )
2015-05-06 13:34:14 -07:00
assert . ok ( $btn . hasClass ( 'active' ) , 'btn has class active' )
2014-02-13 09:55:12 +02:00
} )
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should toggle active when btn children are clicked' , function ( assert ) {
assert . expect ( 2 )
2014-06-18 21:33:38 +02:00
var $btn = $ ( '<button class="btn" data-toggle="button">mdo</button>' )
var $inner = $ ( '<i/>' )
$btn
. append ( $inner )
. appendTo ( '#qunit-fixture' )
2015-05-06 13:34:14 -07:00
assert . ok ( ! $btn . hasClass ( 'active' ) , 'btn does not have active class' )
$inner . trigger ( 'click' )
assert . ok ( $btn . hasClass ( 'active' ) , 'btn has class active' )
2014-02-13 09:55:12 +02:00
} )
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should toggle aria-pressed' , function ( assert ) {
assert . expect ( 2 )
2014-10-17 15:17:57 +01:00
var $btn = $ ( '<button class="btn" data-toggle="button" aria-pressed="false">redux</button>' )
2015-05-06 13:34:14 -07:00
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'false' , 'btn aria-pressed state is false' )
2014-10-17 15:17:57 +01:00
$btn . bootstrapButton ( 'toggle' )
2015-05-06 13:34:14 -07:00
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'true' , 'btn aria-pressed state is true' )
2014-10-17 15:17:57 +01:00
} )
2019-06-05 14:23:25 +01:00
QUnit . test ( 'should not toggle aria-pressed on buttons with disabled class' , function ( assert ) {
assert . expect ( 2 )
var $btn = $ ( '<button class="btn disabled" data-toggle="button" aria-pressed="false">redux</button>' )
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'false' , 'btn aria-pressed state is false' )
$btn . bootstrapButton ( 'toggle' )
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'false' , 'btn aria-pressed state is still false' )
} )
QUnit . test ( 'should not toggle aria-pressed on buttons that are disabled' , function ( assert ) {
assert . expect ( 2 )
var $btn = $ ( '<button class="btn" data-toggle="button" aria-pressed="false" disabled>redux</button>' )
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'false' , 'btn aria-pressed state is false' )
$btn . bootstrapButton ( 'toggle' )
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'false' , 'btn aria-pressed state is still false' )
} )
2016-11-06 14:48:55 +01:00
QUnit . test ( 'should toggle aria-pressed on buttons with container' , function ( assert ) {
assert . expect ( 1 )
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<button id="btn1" class="btn btn-secondary" type="button">One</button>' +
'<button class="btn btn-secondary" type="button">Two</button>' +
'</div>'
$ ( '#qunit-fixture' ) . append ( groupHTML )
$ ( '#btn1' ) . bootstrapButton ( 'toggle' )
assert . strictEqual ( $ ( '#btn1' ) . attr ( 'aria-pressed' ) , 'true' )
} )
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should toggle aria-pressed when btn children are clicked' , function ( assert ) {
assert . expect ( 2 )
2014-10-17 15:17:57 +01:00
var $btn = $ ( '<button class="btn" data-toggle="button" aria-pressed="false">redux</button>' )
var $inner = $ ( '<i/>' )
$btn
. append ( $inner )
. appendTo ( '#qunit-fixture' )
2015-05-06 13:34:14 -07:00
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'false' , 'btn aria-pressed state is false' )
$inner . trigger ( 'click' )
assert . strictEqual ( $btn . attr ( 'aria-pressed' ) , 'true' , 'btn aria-pressed state is true' )
2014-10-17 15:17:57 +01:00
} )
2016-01-14 17:41:36 +01:00
QUnit . test ( 'should trigger input change event when toggled button has input field' , function ( assert ) {
assert . expect ( 1 )
var done = assert . async ( )
2017-12-16 14:00:38 +02:00
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn btn-primary">' +
'<input type="radio" id="radio" autocomplete="off">Radio' +
'</label>' +
'</div>'
2016-01-14 17:41:36 +01:00
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
$group . find ( 'input' ) . on ( 'change' , function ( e ) {
e . preventDefault ( )
assert . ok ( true , 'change event fired' )
done ( )
} )
$group . find ( 'label' ) . trigger ( 'click' )
} )
2015-05-06 13:34:14 -07:00
QUnit . test ( 'should check for closest matching toggle' , function ( assert ) {
assert . expect ( 12 )
2017-12-16 14:00:38 +02:00
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn btn-primary active">' +
'<input type="radio" name="options" id="option1" checked="true"> Option 1' +
'</label>' +
'<label class="btn btn-primary">' +
'<input type="radio" name="options" id="option2"> Option 2' +
'</label>' +
'<label class="btn btn-primary">' +
'<input type="radio" name="options" id="option3"> Option 3' +
'</label>' +
'</div>'
2014-06-18 21:33:38 +02:00
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $btn1 = $group . children ( ) . eq ( 0 )
var $btn2 = $group . children ( ) . eq ( 1 )
2015-05-06 13:34:14 -07:00
assert . ok ( $btn1 . hasClass ( 'active' ) , 'btn1 has active class' )
assert . ok ( $btn1 . find ( 'input' ) . prop ( 'checked' ) , 'btn1 is checked' )
assert . ok ( ! $btn2 . hasClass ( 'active' ) , 'btn2 does not have active class' )
assert . ok ( ! $btn2 . find ( 'input' ) . prop ( 'checked' ) , 'btn2 is not checked' )
$btn2 . find ( 'input' ) . trigger ( 'click' )
assert . ok ( ! $btn1 . hasClass ( 'active' ) , 'btn1 does not have active class' )
assert . ok ( ! $btn1 . find ( 'input' ) . prop ( 'checked' ) , 'btn1 is not checked' )
assert . ok ( $btn2 . hasClass ( 'active' ) , 'btn2 has active class' )
assert . ok ( $btn2 . find ( 'input' ) . prop ( 'checked' ) , 'btn2 is checked' )
2017-12-16 14:00:38 +02:00
$btn2 . find ( 'input' ) . trigger ( 'click' ) // Clicking an already checked radio should not un-check it
2015-05-06 13:34:14 -07:00
assert . ok ( ! $btn1 . hasClass ( 'active' ) , 'btn1 does not have active class' )
assert . ok ( ! $btn1 . find ( 'input' ) . prop ( 'checked' ) , 'btn1 is not checked' )
assert . ok ( $btn2 . hasClass ( 'active' ) , 'btn2 has active class' )
assert . ok ( $btn2 . find ( 'input' ) . prop ( 'checked' ) , 'btn2 is checked' )
2014-02-13 09:55:12 +02:00
} )
2012-08-27 20:58:51 -07:00
2017-04-10 14:43:54 +01:00
QUnit . test ( 'should not add aria-pressed on labels for radio/checkbox inputs in a data-toggle="buttons" group' , function ( assert ) {
assert . expect ( 2 )
2017-12-16 14:00:38 +02:00
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn btn-primary"><input type="checkbox" autocomplete="off"> Checkbox</label>' +
'<label class="btn btn-primary"><input type="radio" name="options" autocomplete="off"> Radio</label>' +
'</div>'
2017-04-10 14:43:54 +01:00
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $btn1 = $group . children ( ) . eq ( 0 )
var $btn2 = $group . children ( ) . eq ( 1 )
$btn1 . find ( 'input' ) . trigger ( 'click' )
assert . ok ( $btn1 . is ( ':not([aria-pressed])' ) , 'label for nested checkbox input has not been given an aria-pressed attribute' )
$btn2 . find ( 'input' ) . trigger ( 'click' )
assert . ok ( $btn2 . is ( ':not([aria-pressed])' ) , 'label for nested radio input has not been given an aria-pressed attribute' )
} )
2017-04-26 19:46:05 +03:00
QUnit . test ( 'should handle disabled attribute on non-button elements' , function ( assert ) {
2019-06-05 14:23:25 +01:00
assert . expect ( 4 )
2017-12-16 14:00:38 +02:00
var groupHTML = '<div class="btn-group disabled" data-toggle="buttons" aria-disabled="true" disabled>' +
2019-06-05 14:23:25 +01:00
'<label class="btn btn-danger disabled">' +
'<input type="checkbox" aria-disabled="true" autocomplete="off" disabled>' +
2017-12-16 14:00:38 +02:00
'</label>' +
'</div>'
2017-04-26 19:46:05 +03:00
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $btn = $group . children ( ) . eq ( 0 )
var $input = $btn . children ( ) . eq ( 0 )
2019-06-05 14:23:25 +01:00
assert . ok ( $btn . is ( ':not(.active)' ) , 'button is initially not active' )
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox is initially not checked' )
$btn [ 0 ] . click ( ) // fire a real click on the DOM node itself, not a click() on the jQuery object that just aliases to trigger('click')
2017-04-26 19:46:05 +03:00
assert . ok ( $btn . is ( ':not(.active)' ) , 'button did not become active' )
2019-06-05 14:23:25 +01:00
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox did not get checked' )
} )
QUnit . test ( 'should not set active class if inner hidden checkbox is disabled but author forgot to set disabled class on outer button' , function ( assert ) {
assert . expect ( 4 )
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn btn-danger">' +
'<input type="checkbox" autocomplete="off" disabled>' +
'</label>' +
'</div>'
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $btn = $group . children ( ) . eq ( 0 )
var $input = $btn . children ( ) . eq ( 0 )
assert . ok ( $btn . is ( ':not(.active)' ) , 'button is initially not active' )
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox is initially not checked' )
$btn [ 0 ] . click ( ) // fire a real click on the DOM node itself, not a click() on the jQuery object that just aliases to trigger('click')
assert . ok ( $btn . is ( ':not(.active)' ) , 'button did not become active' )
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox did not get checked' )
} )
QUnit . test ( 'should correctly set checked state on input and active class on label when using <label><input></label> structure' , function ( assert ) {
assert . expect ( 4 )
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn">' +
'<input type="checkbox" autocomplete="off">' +
'</label>' +
'</div>'
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $label = $group . children ( ) . eq ( 0 )
var $input = $label . children ( ) . eq ( 0 )
assert . ok ( $label . is ( ':not(.active)' ) , 'label is initially not active' )
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox is initially not checked' )
$label [ 0 ] . click ( ) // fire a real click on the DOM node itself, not a click() on the jQuery object that just aliases to trigger('click')
assert . ok ( $label . is ( '.active' ) , 'label is active after click' )
assert . ok ( $input . prop ( 'checked' ) , 'checkbox is checked after click' )
} )
QUnit . test ( 'should correctly set checked state on input and active class on the faked button when using <div><input></div> structure' , function ( assert ) {
assert . expect ( 4 )
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<div class="btn">' +
'<input type="checkbox" autocomplete="off" aria-label="Check">' +
'</div>' +
'</div>'
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $btn = $group . children ( ) . eq ( 0 )
var $input = $btn . children ( ) . eq ( 0 )
assert . ok ( $btn . is ( ':not(.active)' ) , '<div> is initially not active' )
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox is initially not checked' )
$btn [ 0 ] . click ( ) // fire a real click on the DOM node itself, not a click() on the jQuery object that just aliases to trigger('click')
assert . ok ( $btn . is ( '.active' ) , '<div> is active after click' )
assert . ok ( $input . prop ( 'checked' ) , 'checkbox is checked after click' )
} )
QUnit . test ( 'should not do anything if the click was just sent to the outer container with data-toggle' , function ( assert ) {
assert . expect ( 4 )
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn">' +
'<input type="checkbox" autocomplete="off">' +
'</label>' +
'</div>'
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $label = $group . children ( ) . eq ( 0 )
var $input = $label . children ( ) . eq ( 0 )
assert . ok ( $label . is ( ':not(.active)' ) , 'label is initially not active' )
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox is initially not checked' )
$group [ 0 ] . click ( ) // fire a real click on the DOM node itself, not a click() on the jQuery object that just aliases to trigger('click')
assert . ok ( $label . is ( ':not(.active)' ) , 'label is not active after click' )
assert . ok ( ! $input . prop ( 'checked' ) , 'checkbox is not checked after click' )
} )
QUnit . test ( 'should not try and set checked property on an input of type="hidden"' , function ( assert ) {
assert . expect ( 2 )
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn">' +
'<input type="hidden" autocomplete="off">' +
'</label>' +
'</div>'
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $label = $group . children ( ) . eq ( 0 )
var $input = $label . children ( ) . eq ( 0 )
assert . ok ( ! $input . prop ( 'checked' ) , 'hidden input initially has no checked property' )
$label [ 0 ] . click ( ) // fire a real click on the DOM node itself, not a click() on the jQuery object that just aliases to trigger('click')
assert . ok ( ! $input . prop ( 'checked' ) , 'hidden input does not have a checked property' )
} )
QUnit . test ( 'should not try and set checked property on an input that is not a radio button or checkbox' , function ( assert ) {
assert . expect ( 2 )
var groupHTML = '<div class="btn-group" data-toggle="buttons">' +
'<label class="btn">' +
'<input type="text" autocomplete="off">' +
'</label>' +
'</div>'
var $group = $ ( groupHTML ) . appendTo ( '#qunit-fixture' )
var $label = $group . children ( ) . eq ( 0 )
var $input = $label . children ( ) . eq ( 0 )
assert . ok ( ! $input . prop ( 'checked' ) , 'text input initially has no checked property' )
$label [ 0 ] . click ( ) // fire a real click on the DOM node itself, not a click() on the jQuery object that just aliases to trigger('click')
assert . ok ( ! $input . prop ( 'checked' ) , 'text input does not have a checked property' )
2017-04-26 19:46:05 +03:00
} )
2018-04-10 09:28:29 +02:00
QUnit . test ( 'dispose should remove data and the element' , function ( assert ) {
assert . expect ( 2 )
var $el = $ ( '<div/>' )
var $button = $el . bootstrapButton ( )
assert . ok ( typeof $button . data ( 'bs.button' ) !== 'undefined' )
$button . data ( 'bs.button' ) . dispose ( )
assert . ok ( typeof $button . data ( 'bs.button' ) === 'undefined' )
} )
QUnit . test ( 'should return button version' , function ( assert ) {
assert . expect ( 1 )
if ( typeof Button !== 'undefined' ) {
assert . ok ( typeof Button . VERSION === 'string' )
} else {
assert . notOk ( )
}
} )
2013-04-23 17:34:27 +10:00
} )