blob: bc2c3d537e1a2d338fe9d5ba7897ee22c8c790af [file] [log] [blame]
// Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
//
// VMOptions=--lazy-async-stacks
import 'test_helper.dart';
import 'service_test_common.dart';
import 'dart:io';
const int LINE_A = 14;
const String file = "next_through_simple_async_test.dart";
code() async { // LINE_A
File f = new File(Platform.script.toFilePath());
DateTime modified = await f.lastModified();
bool exists = await f.exists();
print("Modified: $modified; exists: $exists");
foo();
}
foo() {
print("Hello from Foo!");
}
List<String> stops = [];
List<String> expected = [
"$file:${LINE_A+0}:5", // on '(' in code()'
"$file:${LINE_A+1}:30", // on 'script'
"$file:${LINE_A+1}:37", // on 'toFilePath'
"$file:${LINE_A+1}:16", // on File
"$file:${LINE_A+2}:31", // on 'lastModified'
"$file:${LINE_A+2}:23", // on 'await'
"$file:${LINE_A+3}:25", // on 'exists'
"$file:${LINE_A+3}:17", // on 'await'
"$file:${LINE_A+4}:47", // on ')', i.e. before ';'
"$file:${LINE_A+4}:3", // on call to 'print'
"$file:${LINE_A+5}:3", // on call to 'foo'
"$file:${LINE_A+6}:1" // ending '}'
];
var tests = <IsolateTest>[
hasPausedAtStart,
setBreakpointAtLine(LINE_A),
runStepThroughProgramRecordingStops(stops),
checkRecordedStops(stops, expected)
];
main(args) {
runIsolateTestsSynchronous(args, tests,
testeeConcurrent: code, pause_on_start: true, pause_on_exit: true);
}