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

Side by Side Diff: runtime/tests/vm/dart/optimized_stacktrace_test.dart

Issue 2687143005: Include metadata in AOT to expand inline frames in stack traces and provide line numbers. (Closed)
Patch Set: . Created 3 years, 10 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
« no previous file with comments | « runtime/tests/vm/dart/optimized_stacktrace_line_test.dart ('k') | runtime/tests/vm/vm.status » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
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.
4 // Test correct source positions in stack trace with optimized functions.
5 import "package:expect/expect.dart";
6
7 // (1) Test normal exception.
8 foo(x) => bar(x);
9
10 bar(x) {
11 if (x == null) throw 42; // throw at position 11:18
12 return x + 1;
13 }
14
15 test1() {
16 // First unoptimized.
17 try {
18 foo(null);
19 Expect.fail("Unreachable");
20 } catch (e, stacktrace) {
21 String s = stacktrace.toString();
22 Expect.isFalse(s.contains("-1:-1"));
23 Expect.isTrue(s.contains("11:18"));
24 }
25
26 // Optimized.
27 for (var i=0; i<10000; i++) foo(42);
28 try {
29 foo(null);
30 Expect.fail("Unreachable");
31 } catch (e, stacktrace) {
32 String s = stacktrace.toString();
33 Expect.isFalse(s.contains("-1:-1"));
34 Expect.isTrue(s.contains("11:18"));
35 }
36 }
37
38
39 // (2) Test checked mode exceptions.
40 maximus(x) => moritz(x);
41
42 moritz(x) {
43 if (x == 333) return 42 ? 0 : 1; // Throws in checked mode.
44 if (x == 777) {
45 bool b = x; // Throws in checked mode.
46 return b;
47 }
48
49 return x + 1;
50 }
51
52 test2() {
53 for (var i=0; i<100000; i++) maximus(42);
54 try {
55 maximus(333);
56 } catch (e, stacktrace) {
57 String s = stacktrace.toString();
58 print(s);
59 Expect.isTrue(s.contains("maximus"));
60 Expect.isTrue(s.contains("moritz"));
61 Expect.isFalse(s.contains("-1:-1"));
62 }
63
64 try {
65 maximus(777);
66 } catch (e, stacktrace) {
67 String s = stacktrace.toString();
68 print(s);
69 Expect.isTrue(s.contains("maximus"));
70 Expect.isTrue(s.contains("moritz"));
71 Expect.isFalse(s.contains("-1:-1"));
72 }
73 }
74
75 main() {
76 test1();
77 test2();
78 }
OLDNEW
« no previous file with comments | « runtime/tests/vm/dart/optimized_stacktrace_line_test.dart ('k') | runtime/tests/vm/vm.status » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698