blob: 8dbdb3457ab8e6828e3adc9b4f6cfb5caf2fd05d [file] [log] [blame]
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001// Copyright 2014 the V8 project authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5// Flags: --allow-natives-syntax --expose-debug-as debug
6
7Debug = debug.Debug
8var exception = null;
9var break_count = 0;
10var expected_breaks = -1;
11
12function listener(event, exec_state, event_data, data) {
13 try {
14 if (event == Debug.DebugEvent.Break) {
15 assertTrue(exec_state.frameCount() != 0, "FAIL: Empty stack trace");
16 if (!break_count) {
17 // Count number of expected breakpoints in this source file.
18 var source_text = exec_state.frame(0).func().script().source();
19 expected_breaks = source_text.match(/\/\/\s*Break\s+\d+\./g).length;
20 print("Expected breaks: " + expected_breaks);
21 }
22 var source = exec_state.frame(0).sourceLineText();
23 print("paused at: " + source);
24 assertTrue(source.indexOf("// Break " + break_count + ".") > 0,
25 "Unexpected pause at: " + source + "\n" +
26 "Expected: // Break " + break_count + ".");
27 if (source.indexOf("StepOver.") !== -1) {
28 exec_state.prepareStep(Debug.StepAction.StepNext, 1);
29 } else {
30 exec_state.prepareStep(Debug.StepAction.StepIn, 1);
31 }
32 ++break_count;
33 }
34 } catch (e) {
35 exception = e;
36 print(e, e.stack);
37 }
38};
39
40Debug.setListener(listener);
41
42Promise.resolve(42)
43 .then(promise1)
44 .then(Object) // Should skip stepping into native.
45 .then(Boolean) // Should skip stepping into native.
46 .then(promise2)
47 .catch(promise3)
48 .catch(function(e) {
49 %AbortJS("FAIL: uncaught exception " + e);
50 });
51
52function promise1() {
53 debugger; // Break 0.
54 return exception || 1; // Break 1.
55} // Break 2.
56
57function promise2() {
58 throw new Error; // Break 3.
59}
60
61function promise3() {
62 installObservers(); // Break 4. StepOver.
63 return break_count; // Break 5.
64} // Break 6.
65
66function installObservers() {
67 var dummy = {};
68 Object.observe(dummy, observer1);
69 Object.observe(dummy, Object); // Should skip stepping into native.
70 Object.observe(dummy, Boolean); // Should skip stepping into native.
71 Object.observe(dummy, observer2);
72 dummy.foo = 1;
73}
74
75function observer1() {
76 return exception || 3; // Break 7.
77} // Break 8.
78
79function observer2() {
80 Promise.resolve().then(promise4); // Break 9. StepOver.
81 return break_count + 1; // Break 10.
82} // Break 11.
83
84function promise4() {
85 finalize(); // Break 12. StepOver.
86 return 0; // Break 13.
87} // Break 14. StepOver.
88
89function finalize() {
90 var dummy = {};
91 Object.observe(dummy, function() {
92 if (expected_breaks !== break_count) {
93 %AbortJS("FAIL: expected <" + expected_breaks + "> breaks instead of <" +
94 break_count + ">");
95 }
96 if (exception !== null) {
97 %AbortJS("FAIL: exception: " + exception);
98 }
99 });
100 dummy.foo = 1;
101}