async-debug-step-nested.js 1.22 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
// Copyright 2016 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

var Debug = debug.Debug;
var step_count = 0;

function listener(event, execState, eventData, data) {
  if (event != Debug.DebugEvent.Break) return;
  try {
    var line = execState.frame(0).sourceLineText();
    print(line);
    var [match, expected_count, step] = /\/\/ B(\d) (\w+)$/.exec(line);
    assertEquals(step_count++, parseInt(expected_count));
    if (step != "Continue") execState.prepareStep(Debug.StepAction[step]);
  } catch (e) {
    print(e, e.stack);
    quit(1);
  }
}

Debug.setListener(listener);

var late_resolve;

function g() {
27
  return new Promise( // B3 StepOut
28 29 30 31 32 33 34 35 36
    function(res, rej) {
      late_resolve = res;
    }
  );
}

async function f1() {
  var a = 1;
  debugger;          // B0 StepNext
37 38
  a +=
       await         // B1 StepIn
39
             f2();   // B2 StepIn
40 41
  return a;          // B5 StepNext
}                    // B6 Continue
42 43

async function f2() {
44 45 46 47
  var b = 0 +        // B2 StepIn
          await
                g();
  return b;          // B4 StepOut
48 49 50 51 52 53 54 55
}

f1();

late_resolve(3);

%RunMicrotasks();

56
assertEquals(7, step_count);