From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- .../async-function/try-throw-finally-reject.js | 26 ++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 js/src/tests/test262/language/expressions/async-function/try-throw-finally-reject.js (limited to 'js/src/tests/test262/language/expressions/async-function/try-throw-finally-reject.js') diff --git a/js/src/tests/test262/language/expressions/async-function/try-throw-finally-reject.js b/js/src/tests/test262/language/expressions/async-function/try-throw-finally-reject.js new file mode 100644 index 0000000000..d2431f4cfb --- /dev/null +++ b/js/src/tests/test262/language/expressions/async-function/try-throw-finally-reject.js @@ -0,0 +1,26 @@ +// |reftest| async +// Copyright 2017 Caitlin Potter. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +author: Caitlin Potter +esid: pending +description: > + Implementations must defer rejecting an async function's Promise until after + all finally blocks have been evaluated. +flags: [async] +---*/ + +var f = async function() { + try { + throw "early-throw"; + } finally { + await new Promise(function(resolve, reject) { + reject("override"); + }); + } +}; + +f().then($DONE, function(value) { + assert.sameValue(value, "override", "Awaited rejection in finally block"); +}).then($DONE, $DONE); -- cgit v1.2.3