Chromium Code Reviews| 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 |