From adfcb6b6c6ac2e57e59dfd4a1124ea8842445b7e Mon Sep 17 00:00:00 2001 From: Marco Castelluccio Date: Thu, 16 Nov 2023 01:03:39 +0000 Subject: [PATCH] Bug 1759031: Let `user-action-pseudo-classes-in-has.html` rely on actions being completed. r=emilio Previously, the test relied upon event listener to listen to related events: e.g. `mousedown` event on `Actions().pointerDown()`. However, as comments in https://github.com/whatwg/html/issues/7578 indicate when `:active` matches does not seem to be interoperable across browsers with different inputs. Instead rely on the action sequence being completed, as done with a simliar test, `html/semantics/selectors/pseudo-classes/active-disabled.html`. Differential Revision: https://phabricator.services.mozilla.com/D193463 UltraBlame original commit: adc6a6f51dfa6facc44c1afe4bf3455c3bf32fad --- ...user-action-pseudo-classes-in-has.html.ini | 28 +- .../user-action-pseudo-classes-in-has.html | 436 +++++++----------- 2 files changed, 177 insertions(+), 287 deletions(-) diff --git a/testing/web-platform/meta/css/selectors/invalidation/user-action-pseudo-classes-in-has.html.ini b/testing/web-platform/meta/css/selectors/invalidation/user-action-pseudo-classes-in-has.html.ini index 86ff56656a2f6..2f80417562eae 100644 --- a/testing/web-platform/meta/css/selectors/invalidation/user-action-pseudo-classes-in-has.html.ini +++ b/testing/web-platform/meta/css/selectors/invalidation/user-action-pseudo-classes-in-has.html.ini @@ -13,35 +13,22 @@ has . html ] -expected -: -if -os -= -= -" -mac -" -: -ERROR [ +CSS +Selectors Invalidation -with -: -focus -: -focus -- -within : -focus +user - -visible +action +pseudo +classes in : has ( ) +argument ] expected : @@ -53,5 +40,4 @@ os mac " : -TIMEOUT FAIL diff --git a/testing/web-platform/tests/css/selectors/invalidation/user-action-pseudo-classes-in-has.html b/testing/web-platform/tests/css/selectors/invalidation/user-action-pseudo-classes-in-has.html index fa43f04e77065..b7a73db19c4c7 100644 --- a/testing/web-platform/tests/css/selectors/invalidation/user-action-pseudo-classes-in-has.html +++ b/testing/web-platform/tests/css/selectors/invalidation/user-action-pseudo-classes-in-has.html @@ -545,28 +545,111 @@ ue004 ' ; -async_test +const +hovermeRect += +hoverme +. +getBoundingClientRect ( -function +) +; +const +focusme1Rect += +focusme1 +. +getBoundingClientRect +( +) +; +promise_test +( +async ( -t ) += +> { -hoverme +assert_equals +( +getComputedStyle +( +subject1 +) . -addEventListener +color +" +rgb ( +0 +0 +0 +) " -mouseover " -t +subject1 +initially +black +" +) +; +assert_equals +( +getComputedStyle +( +subject2 +) . -step_func +color +" +rgb ( -event -= -> +0 +0 +0 +) +" +" +subject3 +initially +black +" +) +; +await +new +test_driver +. +Actions +( +) +. +pointerMove +( +hovermeRect +. +x ++ +1 +hovermeRect +. +y ++ +1 { +origin +: +" +viewport +" +} +) +. +send +( +) +; assert_equals ( getComputedStyle @@ -615,25 +698,43 @@ " ) ; -} -) +await +new +test_driver +. +Actions +( ) -; -hoverme . -addEventListener +pointerMove ( +hovermeRect +. +x ++ +1 +hovermeRect +. +y ++ +1 +{ +origin +: " -mousedown +viewport " -t +} +) . -step_func +pointerDown ( -event -= -> -{ +) +. +send +( +) +; assert_equals ( getComputedStyle @@ -682,25 +783,22 @@ " ) ; -} -) +await +new +test_driver +. +Actions +( ) -; -hoverme . -addEventListener +pointerUp ( -" -mouseup -" -t +) . -step_func +send ( -event -= -> -{ +) +; assert_equals ( getComputedStyle @@ -751,25 +849,47 @@ " ) ; -} -) +await +new +test_driver +. +Actions +( ) -; -focusme1 . -addEventListener +pointerMove ( +focusme1Rect +. +x ++ +1 +focusme1Rect +. +y ++ +1 +{ +origin +: " -focus +viewport " -t +} +) . -step_func +pointerDown ( -function +) +. +pointerUp ( ) -{ +. +send +( +) +; assert_equals ( getComputedStyle @@ -818,6 +938,7 @@ " ) ; +await test_driver . send_keys @@ -828,25 +949,6 @@ tab_key ) ; -} -) -) -; -focusme2 -. -addEventListener -( -" -focus -" -t -. -step_func -( -function -( -) -{ assert_equals ( getComputedStyle @@ -895,6 +997,7 @@ " ) ; +await test_driver . send_keys @@ -905,25 +1008,6 @@ tab_key ) ; -} -) -) -; -focusme3 -. -addEventListener -( -" -focus -" -t -. -step_func -( -function -( -) -{ assert_equals ( getComputedStyle @@ -1026,6 +1110,7 @@ " ) ; +await test_driver . send_keys @@ -1036,25 +1121,6 @@ tab_key ) ; -} -) -) -; -focusme4 -. -addEventListener -( -" -focus -" -t -. -step_func_done -( -function -( -) -{ assert_equals ( getComputedStyle @@ -1159,168 +1225,6 @@ ; } ) -) -; -} -" -Invalidation -with -: -focus -: -focus -- -within -: -focus -- -visible -in -: -has -( -) -" -) -; -test -( -( -) -= -> -{ -assert_equals -( -getComputedStyle -( -subject1 -) -. -color -" -rgb -( -0 -0 -0 -) -" -) -; -assert_equals -( -getComputedStyle -( -subject2 -) -. -color -" -rgb -( -0 -0 -0 -) -" -) -; -} -" -ancestor -should -be -black -" -) -; -let -hovermeRect -= -hoverme -. -getBoundingClientRect -( -) -; -let -focusme1Rect -= -focusme1 -. -getBoundingClientRect -( -) -; -new -test_driver -. -Actions -( -) -. -pointerMove -( -hovermeRect -. -x -+ -1 -hovermeRect -. -y -+ -1 -{ -origin -: -" -viewport -" -} -) -. -pointerDown -( -) -. -pointerUp -( -) -. -pointerMove -( -focusme1Rect -. -x -+ -1 -focusme1Rect -. -y -+ -1 -{ -origin -: -" -viewport -" -} -) -. -pointerDown -( -) -. -pointerUp -( -) -. -send -( -) ; < /