summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/compute-pressure/compute_pressure_disconnect_immediately.https.any.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-15 03:35:49 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-15 03:35:49 +0000
commitd8bbc7858622b6d9c278469aab701ca0b609cddf (patch)
treeeff41dc61d9f714852212739e6b3738b82a2af87 /testing/web-platform/tests/compute-pressure/compute_pressure_disconnect_immediately.https.any.js
parentReleasing progress-linux version 125.0.3-1~progress7.99u1. (diff)
downloadfirefox-d8bbc7858622b6d9c278469aab701ca0b609cddf.tar.xz
firefox-d8bbc7858622b6d9c278469aab701ca0b609cddf.zip
Merging upstream version 126.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/compute-pressure/compute_pressure_disconnect_immediately.https.any.js')
-rw-r--r--testing/web-platform/tests/compute-pressure/compute_pressure_disconnect_immediately.https.any.js67
1 files changed, 67 insertions, 0 deletions
diff --git a/testing/web-platform/tests/compute-pressure/compute_pressure_disconnect_immediately.https.any.js b/testing/web-platform/tests/compute-pressure/compute_pressure_disconnect_immediately.https.any.js
new file mode 100644
index 0000000000..86963e242a
--- /dev/null
+++ b/testing/web-platform/tests/compute-pressure/compute_pressure_disconnect_immediately.https.any.js
@@ -0,0 +1,67 @@
+// META: script=/resources/test-only-api.js
+// META: script=resources/pressure-helpers.js
+// META: global=window,dedicatedworker,sharedworker
+
+'use strict';
+
+pressure_test(async (t, mockPressureService) => {
+ const observer1_changes = [];
+ const observer1 = new PressureObserver(changes => {
+ observer1_changes.push(changes);
+ });
+ t.add_cleanup(() => observer1.disconnect());
+ // Ensure that observer1's schema gets registered before observer2 starts.
+ const promise = observer1.observe('cpu');
+ observer1.disconnect();
+ await promise_rejects_dom(t, 'AbortError', promise);
+
+ const observer2_changes = [];
+ await new Promise((resolve, reject) => {
+ const observer2 = new PressureObserver(changes => {
+ observer2_changes.push(changes);
+ resolve();
+ });
+ t.add_cleanup(() => observer2.disconnect());
+ observer2.observe('cpu').catch(reject);
+ mockPressureService.setPressureUpdate('cpu', 'critical');
+ mockPressureService.startPlatformCollector(/*sampleInterval=*/ 200);
+ });
+
+ assert_equals(
+ observer1_changes.length, 0,
+ 'stopped observers should not receive callbacks');
+
+ assert_equals(observer2_changes.length, 1);
+ assert_equals(observer2_changes[0].length, 1);
+ assert_equals(observer2_changes[0][0].state, 'critical');
+}, 'Stopped PressureObserver do not receive changes');
+
+pressure_test(async (t, mockPressureService) => {
+ const observer1_changes = [];
+ const observer1 = new PressureObserver(changes => {
+ observer1_changes.push(changes);
+ });
+ t.add_cleanup(() => observer1.disconnect());
+
+ const observer2_changes = [];
+ await new Promise(async resolve => {
+ const observer2 = new PressureObserver(changes => {
+ observer2_changes.push(changes);
+ resolve();
+ });
+ t.add_cleanup(() => observer2.disconnect());
+ const promise = observer1.observe('cpu');
+ observer2.observe('cpu');
+ observer1.disconnect();
+ await promise_rejects_dom(t, 'AbortError', promise);
+ mockPressureService.setPressureUpdate('cpu', 'critical');
+ mockPressureService.startPlatformCollector(/*sampleInterval=*/ 200);
+ });
+
+ assert_equals(
+ observer1_changes.length, 0,
+ 'stopped observers should not receive callbacks');
+
+ assert_equals(observer2_changes.length, 1);
+ assert_equals(observer2_changes[0][0].state, 'critical');
+}, 'Removing observer before observe() resolves does not affect other observers');