aboutsummaryrefslogtreecommitdiffstats
path: root/test/unit
diff options
context:
space:
mode:
authorMichał Gołębiowski-Owczarek <m.goleb@gmail.com>2019-04-29 21:40:36 +0200
committerMichał Gołębiowski-Owczarek <m.goleb@gmail.com>2019-04-29 21:40:36 +0200
commit6f2fae7c410dcb5876814866a03fc819f0502290 (patch)
tree74c195bd765ebf234f63fe0945953b473e097466 /test/unit
parent8a741376937dfacf9f82b2b88f93b239fe267435 (diff)
downloadjquery-6f2fae7c410dcb5876814866a03fc819f0502290.tar.gz
jquery-6f2fae7c410dcb5876814866a03fc819f0502290.zip
Tests: Fix the new focusin/focusout test in IE
In IE, focus & blur events fire asynchronously, the test now accounts for that. Ref gh-4362
Diffstat (limited to 'test/unit')
-rw-r--r--test/unit/event.js103
1 files changed, 59 insertions, 44 deletions
diff --git a/test/unit/event.js b/test/unit/event.js
index e5b36c13d..c10341c16 100644
--- a/test/unit/event.js
+++ b/test/unit/event.js
@@ -2952,59 +2952,74 @@ QUnit.test( "focusout/focusin support", function( assert ) {
var focus,
parent = jQuery( "<div>" ),
input = jQuery( "<input>" ),
- inputExternal = jQuery( "<input>" );
+ inputExternal = jQuery( "<input>" ),
+
+ // Support: IE <=9 - 11+
+ // focus and blur events are asynchronous; this is the resulting mess.
+ // The browser window must be topmost for this to work properly!!
+ done = assert.async();
parent.append( input );
jQuery( "#qunit-fixture" ).append( parent ).append( inputExternal );
- parent
- .on( "focus", function() {
- assert.ok( false, "parent: focus not fired" );
- } )
- .on( "focusin", function() {
- assert.ok( true, "parent: focusin fired" );
- } )
- .on( "blur", function() {
- assert.ok( false, "parent: blur not fired" );
- } )
- .on( "focusout", function() {
- assert.ok( true, "parent: focusout fired" );
- } );
+ // initially, lose focus
+ inputExternal[ 0 ].focus();
- input
- .on( "focus", function() {
- assert.ok( true, "element: focus fired" );
- focus = true;
- } )
- .on( "focusin", function() {
- assert.ok( true, "element: focusin fired" );
- } )
- .on( "blur", function() {
- assert.ok( true, "parent: blur fired" );
- } )
- .on( "focusout", function() {
- assert.ok( true, "element: focusout fired" );
- } );
+ setTimeout( function() {
+ parent
+ .on( "focus", function() {
+ assert.ok( false, "parent: focus not fired" );
+ } )
+ .on( "focusin", function() {
+ assert.ok( true, "parent: focusin fired" );
+ } )
+ .on( "blur", function() {
+ assert.ok( false, "parent: blur not fired" );
+ } )
+ .on( "focusout", function() {
+ assert.ok( true, "parent: focusout fired" );
+ } );
- // gain focus
- input.trigger( "focus" );
+ input
+ .on( "focus", function() {
+ assert.ok( true, "element: focus fired" );
+ } )
+ .on( "focusin", function() {
+ assert.ok( true, "element: focusin fired" );
+ focus = true;
+ } )
+ .on( "blur", function() {
+ assert.ok( true, "parent: blur fired" );
+ } )
+ .on( "focusout", function() {
+ assert.ok( true, "element: focusout fired" );
+ } );
- // then lose it
- inputExternal.trigger( "focus" );
+ // gain focus
+ input[ 0 ].focus();
- // cleanup
- parent.off();
- input.off();
+ // then lose it
+ inputExternal[ 0 ].focus();
- // DOM focus is unreliable in TestSwarm
- if ( QUnit.isSwarm && !focus ) {
- assert.ok( true, "GAP: Could not observe focus change" );
- assert.ok( true, "GAP: Could not observe focus change" );
- assert.ok( true, "GAP: Could not observe focus change" );
- assert.ok( true, "GAP: Could not observe focus change" );
- assert.ok( true, "GAP: Could not observe focus change" );
- assert.ok( true, "GAP: Could not observe focus change" );
- }
+ setTimeout( function() {
+
+ // DOM focus is unreliable in TestSwarm
+ if ( QUnit.isSwarm && !focus ) {
+ assert.ok( true, "GAP: Could not observe focus change" );
+ assert.ok( true, "GAP: Could not observe focus change" );
+ assert.ok( true, "GAP: Could not observe focus change" );
+ assert.ok( true, "GAP: Could not observe focus change" );
+ assert.ok( true, "GAP: Could not observe focus change" );
+ assert.ok( true, "GAP: Could not observe focus change" );
+ }
+
+ // cleanup
+ parent.off();
+ input.off();
+
+ done();
+ }, 50 );
+ }, 50 );
} );
QUnit.test( "focus-blur order (#12868)", function( assert ) {