From 1c244cb06a8ff8c87647f68560dff017fa3aaafd Mon Sep 17 00:00:00 2001 From: Marco Castelluccio Date: Tue, 15 Oct 2024 10:49:59 +0000 Subject: [PATCH] Bug 1922836 [wpt PR 48478] - compute pressure: Rewrite rate obfuscation web tests as unit tests, a=testonly Automatic update from web-platform-tests compute pressure: Rewrite rate obfuscation web tests as unit tests These tests have been flaky since they have been rewritten to use WebDriver (bug 347031400). https://crrev.com/c/5898989 added them to SlowTests, but that did not work: contrary to what I expected, marking a test as long in WPT's metadata and adding it to SlowTests are idempotent, not cumulative operations (i.e. I thought adding a test to SlowTests would increase the timeout even more, but it's just a no-op if the test is already marked as long). However, after investigating it further I believe this is not just a timeout problem: these tests cannot work anymore by definition. The idea of these tests is to send a number of updates and verify that: * Sending a number of updates smaller than the spec-defined threshold to trigger the mitigations causes the difference between PressureRecord.time in subsequent updates to be smaller than the penalty time. * Sending a number of updates greater than the spec-defined threshold does trigger the mitigation and cause update N within a spec-defined range to be sent with an implementation-defined delay. In all cases, we need to send an update to WebDriver and verify that PressureObserver has received it before sending the next one. Consequently, the time it takes between sending and receiving updates is actually outside the test's control: busy bots (such as the mac-rel and win-rel ones) can simply cause the web test to WebDriver or the WebDriver to browser process communication to take arbitrarily long, leading to: * Measured time between updates that should not trigger a penalty still taking longer than allowed because the system took too long to deliver the update_virtual_pressure_source() call. This causes the "not triggered" test to fail and leads to false positives in the "triggered" test. * Calls to update_virtual_pressure_source() taking too long to be on the browser side so that and/or too few updates being sent from the browser side while waiting under penalty so that the difference between the pre-penalty update's timestamp and the update-under-penalty's timestamp ends up being less than the minimum penalty time. This makes the "triggered" test never flip the |gotPenalty| flag to true. This was not a problem in the past because the MojoJS-based tests were restricted to Blink. The only way to have full control over the timing is to use unit tests where we can have a mock time source that we move forward as we see fit. Bug: 370726578, 347031400 Change-Id: I9b21513c7b8e83177e7d7b091607100d0cd21c87 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5909373 Reviewed-by: Reilly Grant Auto-Submit: Raphael Kubo Da Costa Commit-Queue: Reilly Grant Commit-Queue: Raphael Kubo Da Costa Cr-Commit-Position: refs/heads/main{#1364368} -- wpt-commits: 5861fcc529a97b8c7c29bde2c9c681f1d2ab33f1 wpt-pr: 48478 UltraBlame original commit: 438fd1d828feba79de38994759cca5d639c47eb2 --- .../tests/compute-pressure/README.md | 105 ------ ...n_mitigation_not_triggered.https.window.js | 286 ---------------- ...ation_mitigation_triggered.https.window.js | 306 ------------------ 3 files changed, 697 deletions(-) delete mode 100644 testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_not_triggered.https.window.js delete mode 100644 testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_triggered.https.window.js diff --git a/testing/web-platform/tests/compute-pressure/README.md b/testing/web-platform/tests/compute-pressure/README.md index 461743b1d8ed..1f8aafe33d67 100644 --- a/testing/web-platform/tests/compute-pressure/README.md +++ b/testing/web-platform/tests/compute-pressure/README.md @@ -28,111 +28,6 @@ specification . # # -Notes -to -implementors -compute_pressure_rate_obfuscation_mitigation_ -* -which -test -the -spec -' -s -[ -rate -obfuscation -sections -] -( -https -: -/ -/ -w3c -. -github -. -io -/ -compute -- -pressure -/ -# -rate -- -obfuscation -) -need -to -send -and -wait -for -dozens -of -updates -. -Some -tests -may -need -to -send -over -90 -changes -and -then -wait -up -to -10 -seconds -for -the -next -update -. -At -1 -change -per -second -this -would -by -far -exceed -WPT -' -s -timeout -limits -so -implementations -need -to -be -able -to -dispatch -updates -at -a -higher -rate -than -usual -for -these -tests -to -pass -. -# -# How to write diff --git a/testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_not_triggered.https.window.js b/testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_not_triggered.https.window.js deleted file mode 100644 index ac683902135c..000000000000 --- a/testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_not_triggered.https.window.js +++ /dev/null @@ -1,286 +0,0 @@ -' -use -strict -' -; -pressure_test -( -async -( -t -) -= -> -{ -await -create_virtual_pressure_source -( -' -cpu -' -) -; -t -. -add_cleanup -( -async -( -) -= -> -{ -await -remove_virtual_pressure_source -( -' -cpu -' -) -; -} -) -; -const -sampleIntervalInMs -= -100 -; -const -readings -= -[ -' -nominal -' -' -fair -' -' -serious -' -' -critical -' -] -; -const -minPenaltyTimeInMs -= -5000 -; -const -minChangesThreshold -= -50 -; -const -changes -= -[ -] -; -const -observer -= -new -PressureObserver -( -updates -= -> -{ -changes -. -push -( -updates -) -; -} -) -; -t -. -add_cleanup -( -( -) -= -> -observer -. -disconnect -( -) -) -; -await -observer -. -observe -( -' -cpu -' -{ -sampleInterval -: -sampleIntervalInMs -} -) -; -let -i -= -0 -; -while -( -changes -. -length -< -minChangesThreshold -) -{ -await -update_virtual_pressure_source -( -' -cpu -' -readings -[ -i -+ -+ -% -readings -. -length -] -) -; -await -t -. -step_wait -( -( -) -= -> -changes -. -length -> -= -i -At -least -{ -i -} -readings -have -been -delivered -) -; -} -observer -. -disconnect -( -) -; -assert_equals -( -changes -. -length -minChangesThreshold -) -; -for -( -let -i -= -0 -; -i -< -( -changes -. -length -- -1 -) -; -i -+ -+ -) -{ -assert_less_than -( -changes -[ -i -+ -1 -] -[ -0 -] -. -time -- -changes -[ -i -] -[ -0 -] -. -time -minPenaltyTimeInMs -' -Not -in -sample -time -boundaries -' -) -; -} -} -' -No -rate -obfuscation -mitigation -should -happen -when -number -of -changes -is -below -minimum -changes -before -penalty -' -) -; -mark_as_done -( -) -; diff --git a/testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_triggered.https.window.js b/testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_triggered.https.window.js deleted file mode 100644 index 3b5c68ffc422..000000000000 --- a/testing/web-platform/tests/compute-pressure/compute_pressure_rate_obfuscation_mitigation_triggered.https.window.js +++ /dev/null @@ -1,306 +0,0 @@ -' -use -strict -' -; -pressure_test -( -async -( -t -) -= -> -{ -await -create_virtual_pressure_source -( -' -cpu -' -) -; -t -. -add_cleanup -( -async -( -) -= -> -{ -await -remove_virtual_pressure_source -( -' -cpu -' -) -; -} -) -; -const -sampleIntervalInMs -= -40 -; -const -readings -= -[ -' -nominal -' -' -fair -' -' -serious -' -' -critical -' -] -; -const -minPenaltyTimeInMs -= -5000 -; -const -maxChangesThreshold -= -100 -; -const -minChangesThreshold -= -50 -; -let -gotPenalty -= -false -; -const -observerChanges -= -[ -] -; -const -observer -= -new -PressureObserver -( -changes -= -> -{ -if -( -observerChanges -. -length -> -= -( -minChangesThreshold -- -1 -) -) -{ -const -lastSample -= -observerChanges -. -at -( -- -1 -) -; -if -( -( -changes -[ -0 -] -. -time -- -lastSample -[ -0 -] -. -time -) -> -= -minPenaltyTimeInMs -) -{ -gotPenalty -= -true -; -observer -. -disconnect -( -) -; -} -} -observerChanges -. -push -( -changes -) -; -} -) -; -t -. -add_cleanup -( -( -) -= -> -observer -. -disconnect -( -) -) -; -observer -. -observe -( -' -cpu -' -{ -sampleInterval -: -sampleIntervalInMs -} -) -; -let -i -= -0 -; -while -( -observerChanges -. -length -< -= -maxChangesThreshold -& -& -! -gotPenalty -) -{ -const -size -= -observerChanges -. -length -; -await -update_virtual_pressure_source -( -' -cpu -' -readings -[ -i -+ -+ -% -readings -. -length -] -) -; -await -t -. -step_wait -( -( -) -= -> -observerChanges -. -length -> -= -i -{ -i -} -readings -have -been -delivered -minPenaltyTimeInMs -* -10 -) -; -} -assert_true -( -gotPenalty -' -Penalty -triggered -' -) -; -} -' -Rate -obfuscation -mitigation -should -have -been -triggered -when -changes -is -higher -than -minimum -changes -before -penalty -' -) -; -mark_as_done -( -) -;