dart-sdk/tests/language/stack_trace/full3_test.dart
Martin Kustermann 8ea636f9f8 [dart2wasm] Make throw call to helper function that gets stacktrace and throws object
This reduces flute complex compiled with `-O4` by 3.2% (or 41kb)

Change-Id: I46e1e933b5b283a7e502571971802885c1c79372
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/349261
Reviewed-by: Slava Egorov <vegorov@google.com>
Commit-Queue: Martin Kustermann <kustermann@google.com>
2024-01-31 08:43:18 +00:00

86 lines
2.3 KiB
Dart

// (c) 2013, 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.
// Avoid dart2js optimizations that alter the JavaScript stack trace. (1)
// dart2js inlines methods in the generated JavaScript which leads to missing
// frames in the stack trace. (2) Minification obfucsates names. Both issues can
// be addressed offline by post-processing the stack trace using the source map
// file.
//
// dart2jsOptions=--disable-inlining --no-minify
import "package:expect/expect.dart";
import 'non_web_helper.dart' if (dart.library.js_interop) 'web_helper.dart';
@pragma("vm:entry-point") // Prevent obfuscation
void func1() {
throw new Exception("Test full stacktrace");
}
@pragma("vm:entry-point") // Prevent obfuscation
void func2() {
func1();
}
@pragma("vm:entry-point") // Prevent obfuscation
void func3() {
try {
func2();
} on Object catch (e, s) {
var fullTrace = s.toString();
Expect.isTrue(fullTrace.contains("func1"));
Expect.isTrue(fullTrace.contains("func2"));
Expect.isTrue(fullTrace.contains("func3"));
Expect.isTrue(fullTrace.contains("func4"));
Expect.isTrue(fullTrace.contains("func5"));
Expect.isTrue(fullTrace.contains("func6"));
Expect.isTrue(fullTrace.contains("func7"));
Expect.isTrue(fullTrace.contains("main"));
throw new Exception("This is not a rethrow");
}
}
@pragma("vm:entry-point") // Prevent obfuscation
int func4() {
func3();
return 1;
}
@pragma("vm:entry-point") // Prevent obfuscation
int func5() {
try {
func4();
} on Object catch (e, s) {
var fullTrace = s.toString();
Expect.isFalse(fullTrace.contains("func1"));
Expect.isFalse(fullTrace.contains("func2"));
Expect.isTrue(fullTrace.contains("func3"));
Expect.isTrue(fullTrace.contains("func4"));
Expect.isTrue(fullTrace.contains("func5"));
Expect.isTrue(fullTrace.contains("func6"));
Expect.isTrue(fullTrace.contains("func7"));
Expect.isTrue(fullTrace.contains("main"));
}
return 1;
}
@pragma("vm:entry-point") // Prevent obfuscation
int func6() {
func5();
return 1;
}
@pragma("vm:entry-point") // Prevent obfuscation
int func7() {
func6();
return 1;
}
main() {
configureStackFrameLimit();
var i = func7();
Expect.equals(1, i);
}