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

Side by Side Diff: test/mjsunit/es6/debug-promises/try-reject-in-constructor.js

Issue 440773004: Trigger exception debug events on Promise reject. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: comments Created 6 years, 4 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 the V8 project authors. All rights reserved. 1 // 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 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 // Test debug events when we only listen to uncaught exceptions and 7 // Test debug events when we only listen to uncaught exceptions and
8 // an exception is thrown in the the Promise constructor. 8 // the Promise is rejected within a try-catch in the Promise constructor.
9 // We expect an Exception debug event with a promise to be triggered. 9 // We expect an Exception debug event with a promise to be triggered.
10 10
11 Debug = debug.Debug; 11 Debug = debug.Debug;
12 12
13 var step = 0; 13 var step = 0;
14 var exception = null; 14 var exception = null;
15 15
16 function listener(event, exec_state, event_data, data) { 16 function listener(event, exec_state, event_data, data) {
17 try { 17 try {
18 // Ignore exceptions during startup in stress runs.
19 if (step >= 1) return;
20 if (event == Debug.DebugEvent.Exception) { 18 if (event == Debug.DebugEvent.Exception) {
21 assertEquals(0, step); 19 assertEquals(0, step);
22 assertEquals("uncaught", event_data.exception().message); 20 assertEquals("uncaught", event_data.exception().message);
23 assertTrue(event_data.promise() instanceof Promise); 21 assertTrue(event_data.promise() instanceof Promise);
24 assertTrue(event_data.uncaught()); 22 assertTrue(event_data.uncaught());
25 // Assert that the debug event is triggered at the throw site. 23 // Assert that the debug event is triggered at the throw site.
26 assertTrue(exec_state.frame(0).sourceLineText().indexOf("// event") > 0); 24 assertTrue(exec_state.frame(0).sourceLineText().indexOf("// event") > 0);
27 step++; 25 step++;
28 } 26 }
29 } catch (e) { 27 } catch (e) {
30 // Signal a failure with exit code 1. This is necessary since the
31 // debugger swallows exceptions and we expect the chained function
32 // and this listener to be executed after the main script is finished.
33 print("Unexpected exception: " + e + "\n" + e.stack);
34 exception = e; 28 exception = e;
35 } 29 }
36 } 30 }
37 31
38 Debug.setBreakOnUncaughtException(); 32 Debug.setBreakOnUncaughtException();
39 Debug.setListener(listener); 33 Debug.setListener(listener);
40 34
41 var p = new Promise(function(resolve, reject) { 35 var p = new Promise(function(resolve, reject) {
42 throw new Error("uncaught"); // event 36 try { // This try-catch must not prevent this uncaught reject event.
37 reject(new Error("uncaught")); // event
38 } catch (e) { }
43 }); 39 });
44 40
45 assertEquals(1, step); 41 assertEquals(1, step);
46 assertNull(exception); 42 assertNull(exception);
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698