mirror of
https://github.com/dart-lang/sdk
synced 2024-09-15 23:49:47 +00:00
de43a7c16a
This option was enabled by default in https://dart-review.googlesource.com/c/sdk/+/149288 This change removes old logic behind --no-lazy-async-stacks and makes --lazy-async-stacks/--no-lazy-async-stacks options no-op. TEST=ci Change-Id: I5726690e90e78dd2ac37d8c5944e388042fc3acf Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/247780 Commit-Queue: Alexander Markov <alexmarkov@google.com> Reviewed-by: Slava Egorov <vegorov@google.com>
77 lines
2.1 KiB
Dart
77 lines
2.1 KiB
Dart
// 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=--verbose_debug
|
|
|
|
import 'dart:developer';
|
|
import 'package:test/test.dart';
|
|
import 'package:vm_service/vm_service.dart';
|
|
|
|
import 'common/service_test_common.dart';
|
|
import 'common/test_helper.dart';
|
|
|
|
const LINE_C = 20;
|
|
const LINE_A = 26;
|
|
const LINE_B = 32;
|
|
|
|
foobar() {
|
|
debugger();
|
|
print('foobar'); // LINE_C.
|
|
}
|
|
|
|
helper() async {
|
|
await 0; // force async gap
|
|
debugger();
|
|
print('helper'); // LINE_A.
|
|
foobar();
|
|
}
|
|
|
|
testMain() {
|
|
debugger();
|
|
helper(); // LINE_B.
|
|
}
|
|
|
|
var tests = <IsolateTest>[
|
|
hasStoppedAtBreakpoint,
|
|
stoppedAtLine(LINE_B),
|
|
(VmService service, IsolateRef isolateRef) async {
|
|
Stack stack = await service.getStack(isolateRef.id!);
|
|
// No causal frames because we are in a completely synchronous stack.
|
|
expect(stack.asyncCausalFrames, isNull);
|
|
},
|
|
resumeIsolate,
|
|
hasStoppedAtBreakpoint,
|
|
stoppedAtLine(LINE_A),
|
|
(VmService service, IsolateRef isolateRef) async {
|
|
Stack stack = await service.getStack(isolateRef.id!);
|
|
// Has causal frames (we are inside an async function)
|
|
expect(stack.asyncCausalFrames, isNotNull);
|
|
expect(
|
|
stack.asyncCausalFrames![0].function!.name,
|
|
contains('helper'),
|
|
);
|
|
// "helper" is not await'ed.
|
|
},
|
|
resumeIsolate,
|
|
hasStoppedAtBreakpoint,
|
|
stoppedAtLine(LINE_C),
|
|
(VmService service, IsolateRef isolateRef) async {
|
|
Stack stack = await service.getStack(isolateRef.id!);
|
|
// Has causal frames (we are inside a function called by an async function)
|
|
expect(stack.asyncCausalFrames, isNotNull);
|
|
final asyncStack = stack.asyncCausalFrames!;
|
|
expect(asyncStack[0].function!.name, contains('foobar'));
|
|
expect(asyncStack[1].function!.name, contains('helper'));
|
|
// "helper" is not await'ed.
|
|
},
|
|
];
|
|
|
|
main(args) => runIsolateTestsSynchronous(
|
|
args,
|
|
tests,
|
|
'causal_async_stack_contents_test.dart',
|
|
testeeConcurrent: testMain,
|
|
extraArgs: extraDebuggingArgs,
|
|
);
|