js/src/jit-test/tests/debug/Frame-onPop-multiple-04.js

Thu, 22 Jan 2015 13:21:57 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 22 Jan 2015 13:21:57 +0100
branch
TOR_BUG_9701
changeset 15
b8a032363ba2
permissions
-rw-r--r--

Incorporate requested changes from Mozilla in review:
https://bugzilla.mozilla.org/show_bug.cgi?id=1123480#c6

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