diff options
Diffstat (limited to 'js/src/tests/test262/language/expressions/async-function/try-reject-finally-reject.js')
-rw-r--r-- | js/src/tests/test262/language/expressions/async-function/try-reject-finally-reject.js | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/js/src/tests/test262/language/expressions/async-function/try-reject-finally-reject.js b/js/src/tests/test262/language/expressions/async-function/try-reject-finally-reject.js new file mode 100644 index 0000000000..ff5ad4c766 --- /dev/null +++ b/js/src/tests/test262/language/expressions/async-function/try-reject-finally-reject.js @@ -0,0 +1,28 @@ +// |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 <caitp@igalia.com> +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 { + await new Promise(function(resolve, reject) { + reject("early-reject"); + }); + } 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); |