| // 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. |
| |
| import 'service_test_common.dart'; |
| import 'test_helper.dart'; |
| |
| const int LINE = 11; |
| const String file = "step_through_function_test.dart"; |
| |
| code() { |
| Bar bar = new Bar(); |
| print(bar.barXYZ1()); |
| print(bar.barXYZ2(4, 2)); |
| print(bar.barXYZ3()); |
| print(bar.barXYZ4(4, 2)); |
| print(fooXYZ1()); |
| print(fooXYZ2(4, 2)); |
| print(fooXYZ3()); |
| print(fooXYZ4(4, 2)); |
| } |
| |
| fooXYZ1 /**/ () => "fooXYZ"; |
| fooXYZ2 /**/ (int i, int j) => "fooXYZ${i}${j}"; |
| fooXYZ3 /**/ () { |
| return "fooXYZ"; |
| } |
| |
| fooXYZ4 /**/ (int i, int j) { |
| return "fooXYZ${i}${j}"; |
| } |
| |
| class Bar { |
| barXYZ1 /**/ () => "barXYZ"; |
| barXYZ2 /**/ (int i, int j) => "barXYZ${i}${j}"; |
| barXYZ3 /**/ () { |
| return "barXYZ"; |
| } |
| |
| barXYZ4 /**/ (int i, int j) { |
| return "barXYZ${i}${j}"; |
| } |
| } |
| |
| List<String> stops = []; |
| List<String> expected = [ |
| "$file:${LINE + 0}:5", // after 'code' |
| "$file:${LINE + 1}:17", // on 'Bar' |
| |
| "$file:${LINE + 2}:13", // on 'barXYZ1' |
| "$file:${LINE + 23}:16", // after 'barXYZ1', i.e. on '(' |
| "$file:${LINE + 23}:22", // on first '"' |
| "$file:${LINE + 2}:3", // on 'print' |
| |
| "$file:${LINE + 3}:13", // on 'barXYZ2' |
| "$file:${LINE + 24}:28", // on 'j' |
| "$file:${LINE + 24}:50", // after last '"', i.e. on ';' |
| "$file:${LINE + 24}:34", // on first '"' |
| "$file:${LINE + 3}:3", // on 'print' |
| |
| "$file:${LINE + 4}:13", // on 'barXYZ3' |
| "$file:${LINE + 25}:16", // after 'barXYZ3', i.e. on '(' |
| "$file:${LINE + 26}:5", // on 'return' |
| "$file:${LINE + 4}:3", // on 'print' |
| |
| "$file:${LINE + 5}:13", // on 'barXYZ4' |
| "$file:${LINE + 29}:28", // on 'j' |
| "$file:${LINE + 30}:28", // after last '"', i.e. on ';' |
| "$file:${LINE + 30}:5", // on 'return' |
| "$file:${LINE + 5}:3", // on 'print' |
| |
| "$file:${LINE + 6}:9", // on 'fooXYZ1' |
| "$file:${LINE + 12}:14", // after 'fooXYZ1', i.e. on '(' |
| "$file:${LINE + 12}:20", // on first '"' |
| "$file:${LINE + 6}:3", // on 'print' |
| |
| "$file:${LINE + 7}:9", // on 'fooXYZ2' |
| "$file:${LINE + 13}:26", // on 'j' |
| "$file:${LINE + 13}:48", // after last '"', i.e. on ';' |
| "$file:${LINE + 13}:32", // on first '"' |
| "$file:${LINE + 7}:3", // on 'print' |
| |
| "$file:${LINE + 8}:9", // on 'fooXYZ3' |
| "$file:${LINE + 14}:14", // after 'fooXYZ3', i.e. on '(' |
| "$file:${LINE + 15}:3", // on 'return' |
| "$file:${LINE + 8}:3", // on 'print' |
| |
| "$file:${LINE + 9}:9", // on 'fooXYZ4' |
| "$file:${LINE + 18}:26", // on 'j' |
| "$file:${LINE + 19}:26", // after last '"', i.e. on ';' |
| "$file:${LINE + 19}:3", // on 'return' |
| "$file:${LINE + 9}:3", // on 'print' |
| |
| "$file:${LINE + 10}:1" // on ending '}' |
| ]; |
| |
| var tests = <IsolateTest>[ |
| hasPausedAtStart, |
| setBreakpointAtLine(LINE), |
| runStepIntoThroughProgramRecordingStops(stops), |
| checkRecordedStops(stops, expected, |
| debugPrint: true, debugPrintFile: file, debugPrintLine: LINE) |
| ]; |
| |
| main(args) { |
| runIsolateTestsSynchronous(args, tests, |
| testeeConcurrent: code, pause_on_start: true, pause_on_exit: true); |
| } |