From 543370c44d38c3bffc4a18a9276c60a330e2abe4 Mon Sep 17 00:00:00 2001 From: Alexey Shvayka Date: Sun, 29 Mar 2020 23:04:54 +0300 Subject: [PATCH] Add `return` method test --- .../return/absent-value-not-passed.js | 43 +++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 test/built-ins/AsyncFromSyncIteratorPrototype/return/absent-value-not-passed.js diff --git a/test/built-ins/AsyncFromSyncIteratorPrototype/return/absent-value-not-passed.js b/test/built-ins/AsyncFromSyncIteratorPrototype/return/absent-value-not-passed.js new file mode 100644 index 0000000000..7772a8e179 --- /dev/null +++ b/test/built-ins/AsyncFromSyncIteratorPrototype/return/absent-value-not-passed.js @@ -0,0 +1,43 @@ +// Copyright (C) 2020 Alexey Shvayka. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +esid: sec-%asyncfromsynciteratorprototype%.return +description: > + `return` method does not pass absent `value`. +info: | + %AsyncFromSyncIteratorPrototype%.return ( value ) + + [...] + 8. If value is present, then + [...] + 9. Else, + a. Let result be Call(return, syncIterator). + [...] +flags: [async] +features: [async-iteration] +---*/ + +var returnArgumentsLength; +var syncIterator = { + [Symbol.iterator]() { + return this; + }, + next() { + return {done: false}; + }, + return() { + returnArgumentsLength = arguments.length; + return {done: true}; + }, +}; + +var asyncIterator = (async function* () { + yield* syncIterator; +})(); + +asyncIterator.next().then(function() { + return asyncIterator.return(); +}).then(function() { + assert.sameValue(returnArgumentsLength, 0); +}).then($DONE, $DONE);