summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/xpcshell/test_nesting-02.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /devtools/server/tests/xpcshell/test_nesting-02.js
parentInitial commit. (diff)
downloadfirefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz
firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'devtools/server/tests/xpcshell/test_nesting-02.js')
-rw-r--r--devtools/server/tests/xpcshell/test_nesting-02.js69
1 files changed, 69 insertions, 0 deletions
diff --git a/devtools/server/tests/xpcshell/test_nesting-02.js b/devtools/server/tests/xpcshell/test_nesting-02.js
new file mode 100644
index 0000000000..27ff17fb98
--- /dev/null
+++ b/devtools/server/tests/xpcshell/test_nesting-02.js
@@ -0,0 +1,69 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+// Test that we can nest event loops and then automatically exit nested event
+// loops when requested.
+
+add_task(
+ threadFrontTest(async ({ threadFront, client }) => {
+ // Reach over the protocol connection and get a reference to the thread actor.
+ // TODO: rewrite the test so we don't do this..
+ const thread = client._transport._serverConnection.getActor(
+ threadFront.actorID
+ );
+
+ test_nesting(thread);
+ })
+);
+
+function test_nesting(thread) {
+ // The following things should happen (in order):
+ // 1. In the new event loop (created by unsafeSynchronize)
+ // 2. Resolve the promise (shouldn't exit any event loops)
+ // 3. Exit the event loop (should also then exit unsafeSynchronize's event loop)
+ // 4. Be after the unsafeSynchronize call
+ let currentStep = 0;
+ const p = new Promise(resolve => {
+ executeSoon(function() {
+ executeSoon(function() {
+ // Should be at step 2
+ Assert.equal(++currentStep, 2);
+ // Before resolving, should have the unsafeSynchronize event loop and the
+ // one just created.
+ Assert.equal(thread._nestedEventLoops.size, 2);
+
+ executeSoon(function() {
+ // Should be at step 3
+ Assert.equal(++currentStep, 3);
+ // Before exiting the manually created event loop, should have the
+ // unsafeSynchronize event loop and the manual event loop.
+ Assert.equal(thread._nestedEventLoops.size, 2);
+ // Should have the event loop
+ Assert.ok(!!eventLoop);
+ eventLoop.resolve();
+ });
+
+ resolve(true);
+ // Shouldn't exit any event loops because a new one started since the call
+ // to unsafeSynchronize
+ Assert.equal(thread._nestedEventLoops.size, 2);
+ });
+
+ // Should be at step 1
+ Assert.equal(++currentStep, 1);
+ // Should have only the unsafeSynchronize event loop
+ Assert.equal(thread._nestedEventLoops.size, 1);
+ const eventLoop = thread._nestedEventLoops.push();
+ eventLoop.enter();
+ });
+ });
+
+ Assert.equal(thread.unsafeSynchronize(p), true);
+
+ // Should be on the fourth step
+ Assert.equal(++currentStep, 4);
+ // There shouldn't be any nested event loops anymore
+ Assert.equal(thread._nestedEventLoops.size, 0);
+}