js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

     1 // Each resumption of an ES6 generator gets a fresh frame, whose onPop
     2 // handler fires the next time the generator yields.  This is not the
     3 // behavior the spec requests, but it's what we do for the moment, and
     4 // it's good to check that at least we don't crash.
     6 load(libdir + 'iteration.js');
     8 var g = newGlobal();
     9 var dbg = new Debugger(g);
    10 var log;
    12 var debuggerFrames = [];
    13 var poppedFrames = [];
    14 dbg.onDebuggerStatement = function handleDebugger(frame) {
    15     log += 'd';
    16     assertEq(frame.type, "call");
    18     assertEq(debuggerFrames.indexOf(frame), -1);
    19     assertEq(poppedFrames.indexOf(frame), -1);
    20     debuggerFrames.push(frame);
    22     if (frame.eval('i').return % 3 == 0) {
    23         frame.onPop = function handlePop(c) {
    24             log += ')' + c.return.value;
    25             assertEq(debuggerFrames.indexOf(this) != -1, true);
    26             assertEq(poppedFrames.indexOf(this), -1);
    27             poppedFrames.push(this);
    28         };
    29     }
    30 };
    32 g.eval("function* g() { for (var i = 0; i < 10; i++) { debugger; yield i; } }");
    33 log ='';
    34 g.eval("var t = 0, iter = g();");
    35 for (var j = 0; j < 10; j++)
    36     g.eval("t += iter.next().value;");
    37 assertIteratorResult(g.eval("iter.next()"), undefined, true);
    38 assertEq(g.eval("t"), 45);
    40 // FIXME: Should equal this, but see bug 917809.
    41 // assertEq(log, "d)0ddd)3ddd)6ddd)9");
    42 assertEq(log, "d)undefinedddd)undefinedddd)undefinedddd)undefined");

mercurial