mirror of https://github.com/tc39/test262.git
Add AsyncIteratorClose tests
This commit is contained in:
parent
fccd9c4b81
commit
df59ad6134
|
@ -0,0 +1,53 @@
|
|||
// 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);
|
|
@ -0,0 +1,52 @@
|
|||
// 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).
|
||||
3. If func is either undefined or null, return undefined.
|
||||
4. If IsCallable(func) is false, throw a TypeError exception.
|
||||
features: [async-iteration]
|
||||
flags: [async]
|
||||
---*/
|
||||
|
||||
const asyncIterable = {};
|
||||
asyncIterable[Symbol.asyncIterator] = function() {
|
||||
return {
|
||||
next: function() {
|
||||
return { done: false, value: null };
|
||||
},
|
||||
return: Symbol(),
|
||||
};
|
||||
};
|
||||
|
||||
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.constructor, TypeError);
|
||||
assert.sameValue(iterationCount, 1, "The loop body is evaluated");
|
||||
}).then($DONE, $DONE);
|
|
@ -0,0 +1,51 @@
|
|||
// 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 throw completion, this error should be suppressed.
|
||||
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 asyncIterable = {};
|
||||
asyncIterable[Symbol.asyncIterator] = function() {
|
||||
return {
|
||||
next: function() {
|
||||
return { done: false, value: null };
|
||||
},
|
||||
get return() {
|
||||
throw { name: "inner error" };
|
||||
},
|
||||
};
|
||||
};
|
||||
|
||||
let iterationCount = 0;
|
||||
const promise = (async function() {
|
||||
for await (const x of asyncIterable) {
|
||||
iterationCount += 1;
|
||||
throw new Test262Error("should not be overriden");
|
||||
}
|
||||
})();
|
||||
|
||||
promise.then(function(value) {
|
||||
throw new Test262Error("Promise should be rejected, got: " + value);
|
||||
}, function(error) {
|
||||
assert.sameValue(error.constructor, Test262Error);
|
||||
assert.sameValue(iterationCount, 1, "The loop body is evaluated");
|
||||
}).then($DONE, $DONE);
|
|
@ -0,0 +1,51 @@
|
|||
// 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 throw completion, this error should be suppressed.
|
||||
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).
|
||||
3. If func is either undefined or null, return undefined.
|
||||
4. If IsCallable(func) is false, throw a TypeError exception.
|
||||
features: [async-iteration]
|
||||
flags: [async]
|
||||
---*/
|
||||
|
||||
const asyncIterable = {};
|
||||
asyncIterable[Symbol.asyncIterator] = function() {
|
||||
return {
|
||||
next: function() {
|
||||
return { done: false, value: null };
|
||||
},
|
||||
return: true,
|
||||
};
|
||||
};
|
||||
|
||||
let iterationCount = 0;
|
||||
const promise = (async function() {
|
||||
for await (const x of asyncIterable) {
|
||||
iterationCount += 1;
|
||||
throw new Test262Error("should not be overriden");
|
||||
}
|
||||
})();
|
||||
|
||||
promise.then(function(value) {
|
||||
throw new Test262Error("Promise should be rejected, got: " + value);
|
||||
}, function(error) {
|
||||
assert.sameValue(error.constructor, Test262Error);
|
||||
assert.sameValue(iterationCount, 1, "The loop body is evaluated");
|
||||
}).then($DONE, $DONE);
|
Loading…
Reference in New Issue