js/src/jit-test/tests/debug/Frame-onPop-multiple-04.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 // If one Debugger's onPop handler causes another Debugger to create a
michael@0 2 // Debugger.Frame instance referring to the same frame, that frame still
michael@0 3 // gets marked as not live after all the onPop handlers have run.
michael@0 4 var g = newGlobal();
michael@0 5 var dbg1 = new Debugger(g);
michael@0 6 var dbg2 = new Debugger(g);
michael@0 7
michael@0 8 var log;
michael@0 9 var frame2;
michael@0 10
michael@0 11 dbg1.onEnterFrame = function handleEnter(frame) {
michael@0 12 log += '(';
michael@0 13 frame.onPop = function handlerPop1(c) {
michael@0 14 log += ')';
michael@0 15 frame2 = dbg2.getNewestFrame();
michael@0 16 assertEq(frame2.live, true);
michael@0 17 frame2.onPop = function handlePop2(c) {
michael@0 18 assertEq("late frame's onPop handler ran",
michael@0 19 "late frame's onPop handler should not run");
michael@0 20 };
michael@0 21 };
michael@0 22 };
michael@0 23
michael@0 24 log = '';
michael@0 25 assertEq(g.eval('40 + 2'), 42);
michael@0 26 assertEq(log, '()');
michael@0 27 assertEq(frame2.live, false);

mercurial