Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(830)

Side by Side Diff: runtime/observatory/tests/service/causal_async_star_stack_contents_test.dart

Issue 2767533002: Revert "Fix observatory tests broken by running dartfmt." (Closed)
Patch Set: Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 // VMOptions=--error_on_bad_type --error_on_bad_override --verbose_debug 4 // VMOptions=--error_on_bad_type --error_on_bad_override --verbose_debug
5 5
6 import 'dart:developer'; 6 import 'dart:developer';
7 import 'package:observatory/models.dart' as M; 7 import 'package:observatory/models.dart' as M;
8 import 'package:observatory/service_io.dart'; 8 import 'package:observatory/service_io.dart';
9 import 'package:unittest/unittest.dart'; 9 import 'package:unittest/unittest.dart';
10 import 'service_test_common.dart'; 10 import 'service_test_common.dart';
11 import 'test_helper.dart'; 11 import 'test_helper.dart';
12 12
13 const LINE_A = 26; 13 const LINE_A = 26;
14 const LINE_B = 19; 14 const LINE_B = 19;
15 const LINE_C = 21; 15 const LINE_C = 21;
16 16
17 foobar() async* { 17 foobar() async* {
18 debugger(); 18 debugger();
19 yield 1; // LINE_B. 19 yield 1; // LINE_B.
20 debugger(); 20 debugger();
21 yield 2; // LINE_C. 21 yield 2; // LINE_C.
22 } 22 }
23 23
24 helper() async { 24 helper() async {
25 debugger(); 25 debugger();
26 print('helper'); // LINE_A. 26 print('helper'); // LINE_A.
27 await for (var i in foobar()) { 27 await for (var i in foobar()) {
28 print('helper $i'); 28 print('helper $i');
29 } 29 }
30 } 30 }
31 31
32 testMain() { 32 testMain() {
33 helper(); 33 helper();
34 } 34 }
35 35
36 var tests = [ 36 var tests = [
37 hasStoppedAtBreakpoint, 37 hasStoppedAtBreakpoint,
38 stoppedAtLine(LINE_A), 38 stoppedAtLine(LINE_A),
39 (Isolate isolate) async { 39 (Isolate isolate) async {
40 ServiceMap stack = await isolate.getStack(); 40 ServiceMap stack = await isolate.getStack();
41 // No causal frames because we are in a completely synchronous stack. 41 // No causal frames because we are in a completely synchronous stack.
42 expect(stack['asyncCausalFrames'], isNotNull); 42 expect(stack['asyncCausalFrames'], isNotNull);
43 var asyncStack = stack['asyncCausalFrames']; 43 var asyncStack = stack['asyncCausalFrames'];
44 expect(asyncStack[0].toString(), contains('helper')); 44 expect(asyncStack[0].toString(), contains('helper'));
45 expect(asyncStack[1].kind, equals(M.FrameKind.asyncSuspensionMarker)); 45 expect(asyncStack[1].kind, equals(M.FrameKind.asyncSuspensionMarker));
46 expect(asyncStack[2].toString(), contains('testMain')); 46 expect(asyncStack[2].toString(), contains('testMain'));
47 }, 47 },
48 resumeIsolate, 48 resumeIsolate,
49 hasStoppedAtBreakpoint, 49 hasStoppedAtBreakpoint,
50 stoppedAtLine(LINE_B), 50 stoppedAtLine(LINE_B),
51
51 (Isolate isolate) async { 52 (Isolate isolate) async {
52 ServiceMap stack = await isolate.getStack(); 53 ServiceMap stack = await isolate.getStack();
53 // Has causal frames (we are inside an async function) 54 // Has causal frames (we are inside an async function)
54 expect(stack['asyncCausalFrames'], isNotNull); 55 expect(stack['asyncCausalFrames'], isNotNull);
55 var asyncStack = stack['asyncCausalFrames']; 56 var asyncStack = stack['asyncCausalFrames'];
56 expect(asyncStack[0].toString(), contains('foobar')); 57 expect(asyncStack[0].toString(), contains('foobar'));
57 expect(asyncStack[1].kind, equals(M.FrameKind.asyncSuspensionMarker)); 58 expect(asyncStack[1].kind, equals(M.FrameKind.asyncSuspensionMarker));
58 expect(asyncStack[2].toString(), contains('helper')); 59 expect(asyncStack[2].toString(), contains('helper'));
59 expect(asyncStack[3].kind, equals(M.FrameKind.asyncSuspensionMarker)); 60 expect(asyncStack[3].kind, equals(M.FrameKind.asyncSuspensionMarker));
60 expect(asyncStack[4].toString(), contains('testMain')); 61 expect(asyncStack[4].toString(), contains('testMain'));
61 }, 62 },
63
62 resumeIsolate, 64 resumeIsolate,
63 hasStoppedAtBreakpoint, 65 hasStoppedAtBreakpoint,
64 stoppedAtLine(LINE_C), 66 stoppedAtLine(LINE_C),
67
65 (Isolate isolate) async { 68 (Isolate isolate) async {
66 ServiceMap stack = await isolate.getStack(); 69 ServiceMap stack = await isolate.getStack();
67 // Has causal frames (we are inside a function called by an async function) 70 // Has causal frames (we are inside a function called by an async function)
68 expect(stack['asyncCausalFrames'], isNotNull); 71 expect(stack['asyncCausalFrames'], isNotNull);
69 var asyncStack = stack['asyncCausalFrames']; 72 var asyncStack = stack['asyncCausalFrames'];
70 print('async:'); 73 print('async:');
71 await printFrames(asyncStack); 74 await printFrames(asyncStack);
72 print('sync:'); 75 print('sync:');
73 await printFrames(stack['frames']); 76 await printFrames(stack['frames']);
74 expect(asyncStack[0].toString(), contains('foobar')); 77 expect(asyncStack[0].toString(), contains('foobar'));
75 expect(asyncStack[1].kind, equals(M.FrameKind.asyncSuspensionMarker)); 78 expect(asyncStack[1].kind, equals(M.FrameKind.asyncSuspensionMarker));
76 expect(asyncStack[2].toString(), contains('helper')); 79 expect(asyncStack[2].toString(), contains('helper'));
77 expect(asyncStack[3].kind, equals(M.FrameKind.asyncSuspensionMarker)); 80 expect(asyncStack[3].kind, equals(M.FrameKind.asyncSuspensionMarker));
78 expect(asyncStack[4].toString(), contains('testMain')); 81 expect(asyncStack[4].toString(), contains('testMain'));
79 // Line 21. 82 // Line 21.
80 expect(await asyncStack[0].location.toUserString(), contains('.dart:21')); 83 expect(await asyncStack[0].location.toUserString(), contains('.dart:21'));
81 // Line 27. 84 // Line 27.
82 expect(await asyncStack[2].location.toUserString(), contains('.dart:27')); 85 expect(await asyncStack[2].location.toUserString(), contains('.dart:27'));
83 // Line 30. 86 // Line 30.
84 expect(await asyncStack[4].location.toUserString(), contains('.dart:33')); 87 expect(await asyncStack[4].location.toUserString(), contains('.dart:33'));
85 }, 88 },
86 ]; 89 ];
87 90
88 main(args) => 91 main(args) => runIsolateTestsSynchronous(args,
89 runIsolateTestsSynchronous(args, tests, testeeConcurrent: testMain); 92 tests,
93 testeeConcurrent: testMain);
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698