jquery-ui/tests/unit/spinner/core.js

277 lines
8.8 KiB
JavaScript
Raw Normal View History

define( [
2016-04-06 13:26:05 +00:00
"qunit",
"jquery",
"lib/helper",
2015-04-07 14:55:52 +00:00
"./helper",
"ui/widgets/spinner"
], function( QUnit, $, helper, testHelper ) {
2011-08-07 12:10:49 +00:00
var simulateKeyDownUp = testHelper.simulateKeyDownUp;
QUnit.module( "spinner: core", { afterEach: helper.moduleAfterEach } );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "markup structure", function( assert ) {
assert.expect( 6 );
var element = $( "#spin" ).spinner(),
spinner = element.spinner( "widget" ),
up = spinner.find( ".ui-spinner-up" ),
down = spinner.find( ".ui-spinner-down" );
assert.hasClasses( element, "ui-spinner-input" );
assert.hasClasses( spinner, "ui-spinner ui-widget ui-widget-content" );
assert.hasClasses( up, "ui-spinner-button ui-spinner-up ui-widget" );
2016-04-06 13:26:05 +00:00
assert.equal( up.length, 1, "Spinner contains exactly one up button" );
assert.hasClasses( down, "ui-spinner-button ui-spinner-down ui-widget" );
2016-04-06 13:26:05 +00:00
assert.equal( down.length, 1, "Spinner contains exactly one down button" );
2015-08-24 12:57:40 +00:00
} );
2016-04-06 13:26:05 +00:00
QUnit.test( "keydown UP on input, increases value not greater than max", function( assert ) {
assert.expect( 5 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 70 ).spinner( {
2011-08-07 12:10:49 +00:00
max: 100,
step: 10
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
simulateKeyDownUp( element, $.ui.keyCode.UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 80 );
simulateKeyDownUp( element, $.ui.keyCode.UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 90 );
simulateKeyDownUp( element, $.ui.keyCode.UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 100 );
simulateKeyDownUp( element, $.ui.keyCode.UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 100 );
simulateKeyDownUp( element, $.ui.keyCode.UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 100 );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "keydown DOWN on input, decreases value not less than min", function( assert ) {
assert.expect( 5 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 50 ).spinner( {
2011-08-07 12:10:49 +00:00
min: 20,
step: 10
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
simulateKeyDownUp( element, $.ui.keyCode.DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 40 );
simulateKeyDownUp( element, $.ui.keyCode.DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 30 );
simulateKeyDownUp( element, $.ui.keyCode.DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
simulateKeyDownUp( element, $.ui.keyCode.DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
simulateKeyDownUp( element, $.ui.keyCode.DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "keydown PAGE_UP on input, increases value not greater than max", function( assert ) {
assert.expect( 5 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 70 ).spinner( {
2011-08-07 12:10:49 +00:00
max: 100,
page: 10
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
simulateKeyDownUp( element, $.ui.keyCode.PAGE_UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 80 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 90 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 100 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 100 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_UP );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 100 );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "keydown PAGE_DOWN on input, decreases value not less than min", function( assert ) {
assert.expect( 5 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 50 ).spinner( {
2011-08-07 12:10:49 +00:00
min: 20,
page: 10
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
simulateKeyDownUp( element, $.ui.keyCode.PAGE_DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 40 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 30 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
simulateKeyDownUp( element, $.ui.keyCode.PAGE_DOWN );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "blur input while spinning with UP", function( assert ) {
var ready = assert.async();
assert.expect( 3 );
var value,
element = $( "#spin" ).val( 10 ).spinner();
function step1() {
element.simulate( "keydown", { keyCode: $.ui.keyCode.UP } );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 11 );
setTimeout( step2, 750 );
}
function step2() {
value = element.val();
2016-04-06 13:26:05 +00:00
assert.ok( value > 11, "repeating while key is down" );
element.on( "blur", function() {
value = element.val();
setTimeout( step3, 750 );
2015-08-24 12:57:40 +00:00
} )[ 0 ].blur();
}
function step3() {
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), value, "stopped repeating on blur" );
ready();
}
element[ 0 ].focus();
setTimeout( step1 );
2015-08-24 12:57:40 +00:00
} );
2016-04-06 13:26:05 +00:00
QUnit.test( "mouse click on up button, increases value not greater than max", function( assert ) {
assert.expect( 3 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 18 ).spinner( {
max: 20
2015-08-24 12:57:40 +00:00
} ),
2011-08-07 22:34:03 +00:00
button = element.spinner( "widget" ).find( ".ui-spinner-up" );
button.trigger( "mousedown" ).trigger( "mouseup" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 19 );
2011-08-07 22:34:03 +00:00
button.trigger( "mousedown" ).trigger( "mouseup" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
2011-08-07 22:34:03 +00:00
button.trigger( "mousedown" ).trigger( "mouseup" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 20 );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "mouse click on up button, increases value not greater than max", function( assert ) {
assert.expect( 3 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 2 ).spinner( {
min: 0
2015-08-24 12:57:40 +00:00
} ),
2011-08-07 22:34:03 +00:00
button = element.spinner( "widget" ).find( ".ui-spinner-down" );
2012-04-19 02:36:15 +00:00
2011-08-07 22:34:03 +00:00
button.trigger( "mousedown" ).trigger( "mouseup" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 1 );
2011-08-07 22:34:03 +00:00
button.trigger( "mousedown" ).trigger( "mouseup" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 0 );
2011-08-07 22:34:03 +00:00
button.trigger( "mousedown" ).trigger( "mouseup" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), 0 );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "mousewheel on input", function( assert ) {
var ready = assert.async();
assert.expect( 5 );
2011-08-07 22:34:03 +00:00
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 0 ).spinner( {
2011-08-07 22:34:03 +00:00
step: 2
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
element.simulate( "focus" );
setTimeout( step1 );
2011-08-07 22:34:03 +00:00
function step1() {
element.trigger( "mousewheel" );
assert.equal( element.val(), 0, "mousewheel event without delta does not change value" );
2011-08-07 12:10:49 +00:00
element.trigger( "mousewheel", 1 );
assert.equal( element.val(), 2, "delta 1" );
element.trigger( "mousewheel", -0.2 );
assert.equal( element.val(), 0, "delta -0.2" );
element.trigger( "mousewheel", -15 );
assert.equal( element.val(), -2, "delta -15" );
2011-08-07 12:10:49 +00:00
element.simulate( "blur" );
setTimeout( step2 );
}
function step2() {
element.trigger( "mousewheel", 1 );
assert.equal( element.val(), -2, "mousewheel when not focused" );
ready();
}
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "reading HTML5 attributes", function( assert ) {
assert.expect( 6 );
2011-08-07 22:34:03 +00:00
var markup = "<input type='number' min='-100' max='100' value='5' step='2'>",
element = $( markup ).spinner();
2016-04-06 13:26:05 +00:00
assert.equal( element.spinner( "option", "min" ), -100, "min from markup" );
assert.equal( element.spinner( "option", "max" ), 100, "max from markup" );
assert.equal( element.spinner( "option", "step" ), 2, "step from markup" );
2011-08-07 22:34:03 +00:00
2015-08-24 12:57:40 +00:00
element = $( markup ).spinner( {
2011-08-07 22:34:03 +00:00
min: -200,
max: 200,
step: 5
2015-08-24 12:57:40 +00:00
} );
2016-04-06 13:26:05 +00:00
assert.equal( element.spinner( "option", "min" ), -200, "min from options" );
assert.equal( element.spinner( "option", "max" ), 200, "max from options" );
assert.equal( element.spinner( "option", "step" ), 5, "stop from options" );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "ARIA attributes", function( assert ) {
assert.expect( 9 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 2 ).spinner( { min: -5, max: 5 } );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
assert.equal( element.attr( "role" ), "spinbutton", "role" );
assert.equal( element.attr( "aria-valuemin" ), "-5", "aria-valuemin" );
assert.equal( element.attr( "aria-valuemax" ), "5", "aria-valuemax" );
assert.equal( element.attr( "aria-valuenow" ), "2", "aria-valuenow" );
2011-08-07 12:10:49 +00:00
element.spinner( "stepUp" );
2016-04-06 13:26:05 +00:00
assert.equal( element.attr( "aria-valuenow" ), "3", "stepUp 1 step changes aria-valuenow" );
2011-08-07 12:10:49 +00:00
element.spinner( "option", { min: -10, max: 10 } );
2016-04-06 13:26:05 +00:00
assert.equal( element.attr( "aria-valuemin" ), "-10", "min option changed aria-valuemin changes" );
assert.equal( element.attr( "aria-valuemax" ), "10", "max option changed aria-valuemax changes" );
element.spinner( "option", "min", null );
2016-04-06 13:26:05 +00:00
assert.equal( element.attr( "aria-valuemin" ), undefined, "aria-valuemin not set when no min" );
element.spinner( "option", "max", null );
2016-04-06 13:26:05 +00:00
assert.equal( element.attr( "aria-valuemax" ), undefined, "aria-valuemax not set when no max" );
2015-08-24 12:57:40 +00:00
} );
2011-08-07 12:10:49 +00:00
2016-04-06 13:26:05 +00:00
QUnit.test( "focus text field when pressing button", function( assert ) {
assert.expect( 2 );
var element = $( "#spin" ).spinner();
$( "body" ).trigger( "focus" );
2016-04-06 13:26:05 +00:00
assert.ok( element[ 0 ] !== document.activeElement, "not focused before" );
element.spinner( "widget" ).find( ".ui-spinner-up" ).trigger( "mousedown" );
2016-04-06 13:26:05 +00:00
assert.ok( element[ 0 ] === document.activeElement, "focused after" );
2015-08-24 12:57:40 +00:00
} );
2016-04-06 13:26:05 +00:00
QUnit.test( "don't clear invalid value on blur", function( assert ) {
assert.expect( 1 );
var element = $( "#spin" ).spinner();
element.trigger( "focus" ).val( "a" ).trigger( "blur" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), "a" );
2015-08-24 12:57:40 +00:00
} );
2016-04-06 13:26:05 +00:00
QUnit.test( "precision", function( assert ) {
assert.expect( 2 );
2015-08-24 12:57:40 +00:00
var element = $( "#spin" ).val( 0.05 ).spinner( {
2012-04-19 02:36:15 +00:00
step: 0.0001
2015-08-24 12:57:40 +00:00
} );
element.spinner( "stepUp" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), "0.0501", "precision from step" );
element.val( 1.05 ).spinner( "option", {
step: 1,
min: -9.95
2015-08-24 12:57:40 +00:00
} );
element.spinner( "stepDown" );
2016-04-06 13:26:05 +00:00
assert.equal( element.val(), "0.05", "precision from min" );
2015-08-24 12:57:40 +00:00
} );
} );