Commit cf75a0b6 authored by yangguo@chromium.org's avatar yangguo@chromium.org

Fix PromiseHasRejectHandler.

The odd-numbered items in the queue are deferred objects, not promises.

R=aandrey@chromium.org

Review URL: https://codereview.chromium.org/473803003

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@23143 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 669305c5
......@@ -332,7 +332,7 @@ var lastMicrotaskId = 0;
// 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;
}
......
......@@ -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;
......
......@@ -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;
......
// 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);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment