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

Side by Side Diff: test/mjsunit/es6/regress/regress-468661.js

Issue 1032653002: Do not assign positions to parser-generated desugarings. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years, 9 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
OLDNEW
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);
OLDNEW
« src/hydrogen.h ('K') | « src/parser.cc ('k') | test/mjsunit/mjsunit.status » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698