toolkit/devtools/server/tests/unit/test_reattach-thread.js

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/toolkit/devtools/server/tests/unit/test_reattach-thread.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,58 @@
     1.4 +/* Any copyright is dedicated to the Public Domain.
     1.5 +   http://creativecommons.org/publicdomain/zero/1.0/ */
     1.6 +
     1.7 +/**
     1.8 + * Test that reattaching to a previously detached thread works.
     1.9 + */
    1.10 +
    1.11 +var gClient, gDebuggee, gThreadClient, gTabClient;
    1.12 +
    1.13 +function run_test()
    1.14 +{
    1.15 +  initTestDebuggerServer();
    1.16 +  gDebuggee = testGlobal("test-reattach");
    1.17 +  DebuggerServer.addTestGlobal(gDebuggee);
    1.18 +
    1.19 +  let transport = DebuggerServer.connectPipe();
    1.20 +  gClient = new DebuggerClient(transport);
    1.21 +  gClient.connect(() => {
    1.22 +    attachTestTab(gClient, "test-reattach", (aReply, aTabClient) => {
    1.23 +      gTabClient = aTabClient;
    1.24 +      test_attach();
    1.25 +    });
    1.26 +  });
    1.27 +  do_test_pending();
    1.28 +}
    1.29 +
    1.30 +function test_attach()
    1.31 +{
    1.32 +  gTabClient.attachThread({}, (aResponse, aThreadClient) => {
    1.33 +    do_check_eq(aThreadClient.state, "paused");
    1.34 +    gThreadClient = aThreadClient;
    1.35 +    aThreadClient.resume(test_detach);
    1.36 +  });
    1.37 +}
    1.38 +
    1.39 +function test_detach()
    1.40 +{
    1.41 +  gThreadClient.detach(() => {
    1.42 +    do_check_eq(gThreadClient.state, "detached");
    1.43 +    do_check_eq(gTabClient.thread, null);
    1.44 +    test_reattach();
    1.45 +  });
    1.46 +}
    1.47 +
    1.48 +function test_reattach()
    1.49 +{
    1.50 +  gTabClient.attachThread({}, (aResponse, aThreadClient) => {
    1.51 +    do_check_neq(gThreadClient, aThreadClient);
    1.52 +    do_check_eq(aThreadClient.state, "paused");
    1.53 +    do_check_eq(gTabClient.thread, aThreadClient);
    1.54 +    aThreadClient.resume(cleanup);
    1.55 +  });
    1.56 +}
    1.57 +
    1.58 +function cleanup()
    1.59 +{
    1.60 +  gClient.close(do_test_finished);
    1.61 +}

mercurial