Chromium Code Reviews| Index: runtime/observatory/tests/service/async_star_step_out_test.dart |
| diff --git a/runtime/observatory/tests/service/async_star_step_out_test.dart b/runtime/observatory/tests/service/async_star_step_out_test.dart |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..b48c7ef26c0c98245a1868dc61af0ea4b3c5928d |
| --- /dev/null |
| +++ b/runtime/observatory/tests/service/async_star_step_out_test.dart |
| @@ -0,0 +1,90 @@ |
| +// 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=--error_on_bad_type --error_on_bad_override --verbose_debug |
| + |
| +import 'dart:developer'; |
| +import 'package:observatory/models.dart' as M; |
| +import 'package:observatory/service_io.dart'; |
| +import 'package:unittest/unittest.dart'; |
| +import 'service_test_common.dart'; |
| +import 'test_helper.dart'; |
| + |
| +const LINE_A = 24; |
| +const LINE_B = 25; |
| +const LINE_C = 29; |
| +const LINE_D = 32; |
| +const LINE_E = 38; |
| +const LINE_F = 39; |
| +const LINE_G = 40; |
| +const LINE_H = 30; |
| +const LINE_I = 34; |
| + |
| +foobar() async* { |
| + yield 1; // LINE_A. |
| + yield 2; // LINE_B. |
| +} |
| + |
| +helper() async { |
| + print('helper'); // LINE_C. |
| + await for (var i in foobar()) { |
| + // LINE_H. |
| + debugger(); |
| + print('loop'); // LINE_D. |
| + } |
| +} // LINE_I. |
| + |
| +testMain() { |
| + debugger(); |
| + print('mmmmm'); // LINE_E. |
| + helper(); // LINE_F. |
| + print('z'); // LINE_G. |
| +} |
| + |
| +var tests = [ |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_E), |
| + stepOver, // print. |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_F), |
| + stepInto, |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_C), |
| + stepOver, // print. |
| + hasStoppedAtBreakpoint, |
| + stepInto, |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_A), |
| + stepOut, // step out of generator. |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_H), // await for. |
| + stepInto, |
| + hasStoppedAtBreakpoint, // debugger(). |
| + stepInto, |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_D), // print. |
| + stepInto, |
| + hasStoppedAtBreakpoint, // await for. |
| + stepInto, |
| + hasStoppedAtBreakpoint, // back in generator. |
| + stoppedAtLine(LINE_B), |
| + stepOut, // step out of generator. |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_H), // await for. |
| + stepInto, |
| + hasStoppedAtBreakpoint, // debugger(). |
| + stepInto, |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_D), // print. |
| + stepInto, |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_H), // await for. |
| + stepInto, |
| + hasStoppedAtBreakpoint, |
| + stepOut, // step out of generator. |
| + hasStoppedAtBreakpoint, |
| + stoppedAtLine(LINE_I), // } tail of helper. |
|
rmacnak
2017/03/29 01:07:54
The implicit return. Maybe use an explicit return
Cutch
2017/03/29 14:39:14
Done.
|
| +]; |
| + |
| +main(args) => |
| + runIsolateTestsSynchronous(args, tests, testeeConcurrent: testMain); |