OLD | NEW |
---|---|
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
adamk
2015/03/24 15:57:41
Nit: 2015
Dmitry Lomov (no reviews)
2015/03/24 16:42:52
Done.
| |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Flags: --expose-debug-as debug | 5 // Flags: --expose-debug-as debug |
6 // Tests stepping into through Array.prototype.forEach callbacks. | 6 // Tests stepping into through Array.prototype.forEach callbacks |
adamk
2015/03/24 15:57:41
This comment either needs updating or removal.
Dmitry Lomov (no reviews)
2015/03/24 16:42:52
Done.
| |
7 | 7 |
8 Debug = debug.Debug | 8 Debug = debug.Debug |
9 var exception = null; | 9 var exception = null; |
10 var break_count = 0; | 10 var break_count = 0; |
11 var expected_breaks = -1; | 11 |
12 var expected_values = | |
13 [ReferenceError, ReferenceError, 0, 0, 0, 0, 0, 1, ReferenceError, ReferenceEr ror]; | |
12 | 14 |
13 function listener(event, exec_state, event_data, data) { | 15 function listener(event, exec_state, event_data, data) { |
14 try { | 16 try { |
15 if (event == Debug.DebugEvent.Break) { | 17 if (event == Debug.DebugEvent.Break) { |
16 assertTrue(exec_state.frameCount() != 0, "FAIL: Empty stack trace"); | 18 assertTrue(exec_state.frameCount() != 0, "FAIL: Empty stack trace"); |
19 // Count number of expected breakpoints in this source file. | |
17 if (!break_count) { | 20 if (!break_count) { |
18 // Count number of expected breakpoints in this source file. | |
19 var source_text = exec_state.frame(0).func().script().source(); | 21 var source_text = exec_state.frame(0).func().script().source(); |
20 expected_breaks = source_text.match(/\/\/\s*Break\s+\d+\./g).length; | 22 expected_breaks = source_text.match(/\/\/\s*Break\s+\d+\./g).length; |
21 print("Expected breaks: " + expected_breaks); | 23 print("Expected breaks: " + expected_breaks); |
22 } | 24 } |
23 var source = exec_state.frame(0).sourceLineText(); | 25 var frameMirror = exec_state.frame(0); |
26 | |
27 var v = null;; | |
28 try { | |
29 v = frameMirror.evaluate('i').value(); | |
30 } catch(e) { | |
31 v = e; | |
32 } | |
33 | |
34 var source = frameMirror.sourceLineText(); | |
24 print("paused at: " + source); | 35 print("paused at: " + source); |
25 assertTrue(source.indexOf("// Break " + break_count + ".") > 0, | 36 assertTrue(source.indexOf("// Break " + break_count + ".") > 0, |
26 "Unexpected pause at: " + source + "\n" + | 37 "Unexpected pause at: " + source + "\n" + |
27 "Expected: // Break " + break_count + "."); | 38 "Expected: // Break " + break_count + "."); |
39 if (expected_values[break_count] === ReferenceError) { | |
40 assertTrue(v instanceof ReferenceError); | |
41 } else { | |
42 assertSame(expected_values[break_count], v); | |
43 } | |
28 ++break_count; | 44 ++break_count; |
45 | |
29 if (break_count !== expected_breaks) { | 46 if (break_count !== expected_breaks) { |
30 exec_state.prepareStep(Debug.StepAction.StepIn, 1); | 47 exec_state.prepareStep(Debug.StepAction.StepIn, 1); |
48 print("Next step prepared"); | |
31 } | 49 } |
32 } | 50 } |
33 } catch(e) { | 51 } catch(e) { |
34 exception = e; | 52 exception = e; |
35 print(e, e.stack); | 53 print(e, e.stack); |
36 } | 54 } |
37 }; | 55 }; |
38 | 56 |
39 Debug.setListener(listener); | 57 Debug.setListener(listener); |
40 | 58 |
41 debugger; // Break 0. | 59 var sum = 0; |
42 [1,2].forEach(callback); // Break 1. | 60 (function (){ |
61 'use strict'; | |
43 | 62 |
44 function callback(x) { | 63 debugger; // Break 0. |
45 return x; // Break 2. // Break 4. | |
46 } // Break 3. // Break 5. | |
47 | 64 |
48 assertNull(exception); // Break 6. | 65 for (let i=0; // Break 1. |
66 i < 1; // Break 2. // Break 3. // Break 6. // Break 7. | |
67 i++) { | |
adamk
2015/03/24 15:57:41
Can you explain why we don't break on this line? I
Dmitry Lomov (no reviews)
2015/03/24 16:42:52
No I do not know why do not break on this line. I
adamk
2015/03/24 16:48:47
Yeah, I tried this myself and saw the same behavio
| |
68 let key = i; // Break 4. | |
69 sum += key; // Break 5. | |
70 } | |
71 }()); // Break 8. | |
72 | |
73 assertNull(exception); // Break 9. | |
49 assertEquals(expected_breaks, break_count); | 74 assertEquals(expected_breaks, break_count); |
50 | 75 |
51 Debug.setListener(null); | 76 Debug.setListener(null); |
OLD | NEW |