diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js')
-rw-r--r-- | js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js b/js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js new file mode 100644 index 000000000..5e701a3ab --- /dev/null +++ b/js/src/jit-test/tests/debug/Frame-onPop-star-generators-03.js @@ -0,0 +1,42 @@ +// Each resumption of an ES6 generator gets a fresh frame, whose onPop +// handler fires the next time the generator yields. This is not the +// behavior the spec requests, but it's what we do for the moment, and +// it's good to check that at least we don't crash. + +load(libdir + 'iteration.js'); + +var g = newGlobal(); +var dbg = new Debugger(g); +var log; + +var debuggerFrames = []; +var poppedFrames = []; +dbg.onDebuggerStatement = function handleDebugger(frame) { + log += 'd'; + assertEq(frame.type, "call"); + + assertEq(debuggerFrames.indexOf(frame), -1); + assertEq(poppedFrames.indexOf(frame), -1); + debuggerFrames.push(frame); + + if (frame.eval('i').return % 3 == 0) { + frame.onPop = function handlePop(c) { + log += ')' + c.return.value; + assertEq(debuggerFrames.indexOf(this) != -1, true); + assertEq(poppedFrames.indexOf(this), -1); + poppedFrames.push(this); + }; + } +}; + +g.eval("function* g() { for (var i = 0; i < 10; i++) { debugger; yield i; } }"); +log =''; +g.eval("var t = 0, iter = g();"); +for (var j = 0; j < 10; j++) + g.eval("t += iter.next().value;"); +assertIteratorResult(g.eval("iter.next()"), undefined, true); +assertEq(g.eval("t"), 45); + +// FIXME: Should equal this, but see bug 917809. +// assertEq(log, "d)0ddd)3ddd)6ddd)9"); +assertEq(log, "d)undefinedddd)undefinedddd)undefinedddd)undefined"); |