js/src/jit-test/tests/debug/Frame-evalWithBindings-07.js

Thu, 15 Jan 2015 21:03:48 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 15 Jan 2015 21:03:48 +0100
branch
TOR_BUG_9701
changeset 11
deefc01c0e14
permissions
-rw-r--r--

Integrate friendly tips from Tor colleagues to make (or not) 4.5 alpha 3;
This includes removal of overloaded (but unused) methods, and addition of
a overlooked call to DataStruct::SetData(nsISupports, uint32_t, bool.)

michael@0 1 // var statements in strict evalWithBindings code behave like strict eval.
michael@0 2 var g = newGlobal();
michael@0 3 var dbg = new Debugger(g);
michael@0 4 var hits = 0;
michael@0 5 dbg.onDebuggerStatement = function (frame) {
michael@0 6 assertEq(frame.evalWithBindings("var i = a*a + b*b; i === 25;", {a: 3, b: 4}).return, true);
michael@0 7 hits++;
michael@0 8 };
michael@0 9 g.eval("'use strict'; debugger;");
michael@0 10 assertEq(hits, 1);
michael@0 11 assertEq("i" in g, false);
michael@0 12
michael@0 13 g.eval("function die() { throw fit; }");
michael@0 14 g.eval("Object.defineProperty(this, 'i', {get: die, set: die});");
michael@0 15 g.eval("'use strict'; debugger;");
michael@0 16 assertEq(hits, 2);

mercurial