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

Side by Side Diff: test/mjsunit/ignition/debug-break-on-stack.js

Issue 1723803004: [interpreter, debugger] replace bytecode on-stack for debugging. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: fix Created 4 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 | « src/debug/debug.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2016 the V8 project authors. All rights reserved. 1 // Copyright 2016 the V8 project authors. All rights reserved.
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 6
7 var Debug = debug.Debug; 7 var Debug = debug.Debug;
8 8
9 var break_count = 0; 9 var break_count = 0;
10 var exception = null; 10 var exception = null;
11 11
12 function listener(event, exec_state, event_data, data) { 12 function listener(event, exec_state, event_data, data) {
13 if (event != Debug.DebugEvent.Break) return; 13 if (event != Debug.DebugEvent.Break) return;
14 try { 14 try {
15 break_count++; 15 break_count++;
16 var line = exec_state.frame(0).sourceLineText(); 16 var line = exec_state.frame(0).sourceLineText();
17 print(line);
17 assertTrue(line.indexOf(`B${break_count}`) > 0); 18 assertTrue(line.indexOf(`B${break_count}`) > 0);
18 } catch (e) { 19 } catch (e) {
19 exception = e; 20 exception = e;
20 } 21 }
21 } 22 }
22 23
23 Debug.setListener(listener);
24 24
25 function g() { 25 function g() {
26 throw 1; 26 setbreaks();
27 throw 1; // B1
27 } 28 }
28 29
29 function f() { 30 function f() {
30 try { 31 try {
31 g(); // B1 32 g();
32 } catch (e) {} 33 } catch (e) {}
33 assertEquals(2, break_count); // B2 34 return 2; // B2
34 return 1; // B3
35 } 35 }
36 36
37 Debug.setBreakPoint(f, 2, 0); 37 function setbreaks() {
38 Debug.setBreakPoint(f, 4, 1); 38 Debug.setListener(listener);
39 Debug.setBreakPoint(f, 5, 1); 39 Debug.setBreakPoint(g, 2, 0);
40 Debug.setBreakPoint(f, 4, 0);
41 }
40 42
41 f(); 43 f();
42 44
43 assertEquals(3, break_count); 45 assertEquals(2, break_count);
44 assertNull(exception); 46 assertNull(exception);
45 47
46 Debug.setListener(null); 48 Debug.setListener(null);
OLDNEW
« no previous file with comments | « src/debug/debug.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698