toolkit/devtools/server/tests/unit/test_nesting-01.js

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

     1 /* -*- Mode: javascript; js-indent-level: 2; -*- */
     2 /* Any copyright is dedicated to the Public Domain.
     3    http://creativecommons.org/publicdomain/zero/1.0/ */
     5 // Test that we can nest event loops when needed in
     6 // ThreadActor.prototype.synchronize.
     8 var gClient;
     9 var gThreadActor;
    11 function run_test() {
    12   initTestDebuggerServer();
    13   let gDebuggee = addTestGlobal("test-nesting");
    14   gClient = new DebuggerClient(DebuggerServer.connectPipe());
    15   gClient.connect(function () {
    16     attachTestTabAndResume(gClient, "test-nesting", function (aResponse, aTabClient, aThreadClient) {
    17       // Reach over the protocol connection and get a reference to the thread actor.
    18       gThreadActor = aThreadClient._transport._serverConnection.getActor(aThreadClient._actor);
    20       test_nesting();
    21     });
    22   });
    23   do_test_pending();
    24 }
    26 function test_nesting() {
    27   const thread = gThreadActor;
    28   const { resolve, reject, promise: p } = promise.defer();
    30   let currentStep = 0;
    32   executeSoon(function () {
    33     // Should be on the first step
    34     do_check_eq(++currentStep, 1);
    35     // We should have one nested event loop from synchronize
    36     do_check_eq(thread._nestedEventLoops.size, 1);
    37     resolve(true);
    38   });
    40   do_check_eq(thread.synchronize(p), true);
    42   // Should be on the second step
    43   do_check_eq(++currentStep, 2);
    44   // There shouldn't be any nested event loops anymore
    45   do_check_eq(thread._nestedEventLoops.size, 0);
    47   finishClient(gClient);
    48 }

mercurial