blob: ae1e936d0a2a65ef600efa3a6de15f1ce82f3895 [file] [log] [blame]
// (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"));
rethrow; // This is 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.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"));
}
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);
}