1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
// |reftest| async
// Copyright (C) 2020 Alexey Shvayka. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-asynciteratorclose
description: >
If retrieving an iterator's `return` method generates an error while
closing the iterator with non-throw completion, the error should be
forwarded to the runtime.
info: |
AsyncIteratorClose ( iteratorRecord, completion )
[...]
4. Let innerResult be GetMethod(iterator, "return").
5. If innerResult.[[Type]] is normal,
[...]
6. If completion.[[Type]] is throw, return Completion(completion).
7. If innerResult.[[Type]] is throw, return Completion(innerResult).
GetMethod ( V, P )
[...]
2. Let func be ? GetV(V, P).
features: [async-iteration]
flags: [async]
---*/
const innerError = { name: "inner error" };
const asyncIterable = {};
asyncIterable[Symbol.asyncIterator] = function() {
return {
next: function() {
return { done: false, value: null };
},
get return() {
throw innerError;
},
};
};
let iterationCount = 0;
const promise = (async function() {
for await (const x of asyncIterable) {
iterationCount += 1;
break;
}
})();
promise.then(function(value) {
throw new Test262Error("Promise should be rejected, got: " + value);
}, function(error) {
assert.sameValue(error, innerError);
assert.sameValue(iterationCount, 1, "The loop body is evaluated");
}).then($DONE, $DONE);
|