toolkit/devtools/server/tests/unit/test_framebindings-02.js

Sat, 03 Jan 2015 20:18:00 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Sat, 03 Jan 2015 20:18:00 +0100
branch
TOR_BUG_3246
changeset 7
129ffea94266
permissions
-rw-r--r--

Conditionally enable double key logic according to:
private browsing mode or privacy.thirdparty.isolate preference and
implement in GetCookieStringCommon and FindCookie where it counts...
With some reservations of how to convince FindCookie users to test
condition and pass a nullptr when disabling double key logic.

michael@0 1 /* Any copyright is dedicated to the Public Domain.
michael@0 2 http://creativecommons.org/publicdomain/zero/1.0/ */
michael@0 3
michael@0 4 /**
michael@0 5 * Check a frame actor's parent bindings.
michael@0 6 */
michael@0 7
michael@0 8 var gDebuggee;
michael@0 9 var gClient;
michael@0 10 var gThreadClient;
michael@0 11
michael@0 12 function run_test()
michael@0 13 {
michael@0 14 initTestDebuggerServer();
michael@0 15 gDebuggee = addTestGlobal("test-stack");
michael@0 16 gClient = new DebuggerClient(DebuggerServer.connectPipe());
michael@0 17 gClient.connect(function() {
michael@0 18 attachTestTabAndResume(gClient, "test-stack", function(aResponse, aTabClient, aThreadClient) {
michael@0 19 gThreadClient = aThreadClient;
michael@0 20 test_pause_frame();
michael@0 21 });
michael@0 22 });
michael@0 23 do_test_pending();
michael@0 24 }
michael@0 25
michael@0 26 function test_pause_frame()
michael@0 27 {
michael@0 28 gThreadClient.addOneTimeListener("paused", function(aEvent, aPacket) {
michael@0 29 let parentEnv = aPacket.frame.environment.parent;
michael@0 30 let bindings = parentEnv.bindings;
michael@0 31 let args = bindings.arguments;
michael@0 32 let vars = bindings.variables;
michael@0 33 do_check_neq(parentEnv, undefined);
michael@0 34 do_check_eq(args.length, 0);
michael@0 35 do_check_eq(vars.stopMe.value.type, "object");
michael@0 36 do_check_eq(vars.stopMe.value.class, "Function");
michael@0 37 do_check_true(!!vars.stopMe.value.actor);
michael@0 38
michael@0 39 parentEnv = parentEnv.parent;
michael@0 40 do_check_neq(parentEnv, undefined);
michael@0 41 let objClient = gThreadClient.pauseGrip(parentEnv.object);
michael@0 42 objClient.getPrototypeAndProperties(function(aResponse) {
michael@0 43 do_check_eq(aResponse.ownProperties.Object.value.type, "object");
michael@0 44 do_check_eq(aResponse.ownProperties.Object.value.class, "Function");
michael@0 45 do_check_true(!!aResponse.ownProperties.Object.value.actor);
michael@0 46
michael@0 47 gThreadClient.resume(function() {
michael@0 48 finishClient(gClient);
michael@0 49 });
michael@0 50 });
michael@0 51 });
michael@0 52
michael@0 53 gDebuggee.eval("(" + function() {
michael@0 54 function stopMe(aNumber, aBool, aString, aNull, aUndefined, aObject) {
michael@0 55 var a = 1;
michael@0 56 var b = true;
michael@0 57 var c = { a: "a" };
michael@0 58 debugger;
michael@0 59 };
michael@0 60 stopMe(42, true, "nasu", null, undefined, { foo: "bar" });
michael@0 61 } + ")()");
michael@0 62 }

mercurial