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

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,42 @@
     1.4 +// Each resumption of an ES6 generator gets a fresh frame, whose onPop
     1.5 +// handler fires the next time the generator yields.  This is not the
     1.6 +// behavior the spec requests, but it's what we do for the moment, and
     1.7 +// it's good to check that at least we don't crash.
     1.8 +
     1.9 +load(libdir + 'iteration.js');
    1.10 +
    1.11 +var g = newGlobal();
    1.12 +var dbg = new Debugger(g);
    1.13 +var log;
    1.14 +
    1.15 +var debuggerFrames = [];
    1.16 +var poppedFrames = [];
    1.17 +dbg.onDebuggerStatement = function handleDebugger(frame) {
    1.18 +    log += 'd';
    1.19 +    assertEq(frame.type, "call");
    1.20 +
    1.21 +    assertEq(debuggerFrames.indexOf(frame), -1);
    1.22 +    assertEq(poppedFrames.indexOf(frame), -1);
    1.23 +    debuggerFrames.push(frame);
    1.24 +
    1.25 +    if (frame.eval('i').return % 3 == 0) {
    1.26 +        frame.onPop = function handlePop(c) {
    1.27 +            log += ')' + c.return.value;
    1.28 +            assertEq(debuggerFrames.indexOf(this) != -1, true);
    1.29 +            assertEq(poppedFrames.indexOf(this), -1);
    1.30 +            poppedFrames.push(this);
    1.31 +        };
    1.32 +    }
    1.33 +};
    1.34 +
    1.35 +g.eval("function* g() { for (var i = 0; i < 10; i++) { debugger; yield i; } }");
    1.36 +log ='';
    1.37 +g.eval("var t = 0, iter = g();");
    1.38 +for (var j = 0; j < 10; j++)
    1.39 +    g.eval("t += iter.next().value;");
    1.40 +assertIteratorResult(g.eval("iter.next()"), undefined, true);
    1.41 +assertEq(g.eval("t"), 45);
    1.42 +
    1.43 +// FIXME: Should equal this, but see bug 917809.
    1.44 +// assertEq(log, "d)0ddd)3ddd)6ddd)9");
    1.45 +assertEq(log, "d)undefinedddd)undefinedddd)undefinedddd)undefined");

mercurial