Revision: 23143
Author: [email protected]
Date: Mon Aug 18 08:43:11 2014 UTC
Log: Fix PromiseHasRejectHandler.
The odd-numbered items in the queue are deferred objects, not promises.
[email protected]
Review URL: https://codereview.chromium.org/473803003
http://code.google.com/p/v8/source/detail?r=23143
Added:
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/throw-eventually-caught.js
Modified:
/branches/bleeding_edge/src/promise.js
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/reject-caught-by-default-reject-handler.js
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/throw-caught-by-default-reject-handler.js
=======================================
--- /dev/null
+++
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/throw-eventually-caught.js
Mon Aug 18 08:43:11 2014 UTC
@@ -0,0 +1,42 @@
+// Copyright 2014 the V8 project authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// Flags: --expose-debug-as debug --allow-natives-syntax
+
+// Test debug events when we only listen to uncaught exceptions and
+// there is a catch handler for the to-be-rejected Promise.
+// We expect no Exception debug events, since the default reject handler
passes
+// the rejection on to a user-defined reject handler.
+
+Debug = debug.Debug;
+
+var resolve, reject;
+var p0 = new Promise(function(res, rej) { resolve = res; reject = rej; });
+
+var p1 = p0.then(function() {
+ throw new Error();
+});
+
+var p2 = p1.then(function() { });
+var p3 = p2.catch(function() { });
+
+var q = new Promise(function(res, rej) {
+ res();
+});
+
+q.then(function() {
+ resolve();
+})
+
+
+function listener(event, exec_state, event_data, data) {
+ try {
+ assertTrue(event != Debug.DebugEvent.Exception);
+ } catch (e) {
+ %AbortJS(e + "\n" + e.stack);
+ }
+}
+
+Debug.setBreakOnUncaughtException();
+Debug.setListener(listener);
=======================================
--- /branches/bleeding_edge/src/promise.js Thu Aug 14 06:57:48 2014 UTC
+++ /branches/bleeding_edge/src/promise.js Mon Aug 18 08:43:11 2014 UTC
@@ -332,7 +332,7 @@
// the default PromiseIdRejectHandler.
for (var i = 0; i < queue.length; i += 2) {
if (queue[i] != PromiseIdRejectHandler) return true;
- if (PromiseHasRejectHandlerRecursive(queue[i + 1])) return true;
+ if (PromiseHasRejectHandlerRecursive(queue[i + 1].promise)) return
true;
}
return false;
}
=======================================
---
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/reject-caught-by-default-reject-handler.js
Thu Aug 14 07:11:44 2014 UTC
+++
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/reject-caught-by-default-reject-handler.js
Mon Aug 18 08:43:11 2014 UTC
@@ -5,8 +5,10 @@
// Flags: --expose-debug-as debug --allow-natives-syntax
// Test debug events when we only listen to uncaught exceptions and
-// there is a catch handler for the to-be-rejected Promise.
-// We expect an Exception debug event with a promise to be triggered.
+// there is only a default reject handler for the to-be-rejected Promise.
+// We expect two Exception debug events:
+// - when the first Promise is rejected and only has default reject
handlers.
+// - when the default reject handler passes the rejection on.
Debug = debug.Debug;
=======================================
---
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/throw-caught-by-default-reject-handler.js
Thu Aug 14 07:11:44 2014 UTC
+++
/branches/bleeding_edge/test/mjsunit/es6/debug-promises/throw-caught-by-default-reject-handler.js
Mon Aug 18 08:43:11 2014 UTC
@@ -5,8 +5,10 @@
// Flags: --expose-debug-as debug --allow-natives-syntax
// Test debug events when we only listen to uncaught exceptions and
-// there is a catch handler for the to-be-rejected Promise.
-// We expect an Exception debug event with a promise to be triggered.
+// there is only a default reject handler for the to-be-rejected Promise.
+// We expect two Exception debug events:
+// - when the first Promise is rejected and only has default reject
handlers.
+// - when the default reject handler passes the rejection on.
Debug = debug.Debug;
--
--
v8-dev mailing list
[email protected]
http://groups.google.com/group/v8-dev
---
You received this message because you are subscribed to the Google Groups "v8-dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
For more options, visit https://groups.google.com/d/optout.