Skip to content

Commit

Permalink
Add AsyncIteratorClose tests
Browse files Browse the repository at this point in the history
  • Loading branch information
shvaikalesh authored and rwaldron committed Apr 2, 2020
1 parent fccd9c4 commit df59ad6
Show file tree
Hide file tree
Showing 4 changed files with 207 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -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);
Original file line number Diff line number Diff line change
@@ -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);
Original file line number Diff line number Diff line change
@@ -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);
Original file line number Diff line number Diff line change
@@ -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);

0 comments on commit df59ad6

Please sign in to comment.