js/src/jit-test/tests/debug/Script-getLineOffsets-02.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/Script-getLineOffsets-02.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,33 @@
     1.4 +// getLineOffsets correctly places the various parts of a ForStatement.
     1.5 +
     1.6 +var g = newGlobal();
     1.7 +var dbg = Debugger(g);
     1.8 +dbg.onDebuggerStatement = function (frame) {
     1.9 +    function handler(line) {
    1.10 +        return {hit: function (frame) { g.log += "" + line; }};
    1.11 +    }
    1.12 +
    1.13 +    var s = frame.eval("f").return.script;
    1.14 +    for (var line = 2; line <= 6; line++) {
    1.15 +        var offs = s.getLineOffsets(g.line0 + line);
    1.16 +        var h = handler(line);
    1.17 +        for (var i = 0; i < offs.length; i++) {
    1.18 +            assertEq(s.getOffsetLine(offs[i]), g.line0 + line);
    1.19 +            s.setBreakpoint(offs[i], h);
    1.20 +        }
    1.21 +    }
    1.22 +};
    1.23 +
    1.24 +g.log = '';
    1.25 +g.eval("var line0 = Error().lineNumber;\n" +
    1.26 +       "function f(n) {\n" +        // line0 + 1
    1.27 +       "    for (var i = 0;\n" +    // line0 + 2
    1.28 +       "         i < n;\n" +        // line0 + 3
    1.29 +       "         i++)\n" +          // line0 + 4
    1.30 +       "        log += '.';\n" +    // line0 + 5
    1.31 +       "    log += '!';\n" +        // line0 + 6
    1.32 +       "}\n" +
    1.33 +       "debugger;\n");
    1.34 +assertEq(g.log, "");
    1.35 +g.f(3);
    1.36 +assertEq(g.log, "235.435.435.436!");

mercurial