2015-05-19 18:48:52 +02:00
|
|
|
// Copyright (C) 2015 the V8 project authors. All rights reserved.
|
|
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
/*---
|
2021-12-07 17:00:43 +01:00
|
|
|
esid: sec-set-constructor
|
2015-05-19 18:48:52 +02:00
|
|
|
description: >
|
|
|
|
Set ( [ iterable ] )
|
|
|
|
|
|
|
|
When the Set function is called with optional argument iterable the following steps are taken:
|
|
|
|
|
|
|
|
...
|
|
|
|
9. Repeat
|
|
|
|
a. Let next be IteratorStep(iter).
|
|
|
|
b. ReturnIfAbrupt(next).
|
|
|
|
c. If next is false, return set.
|
|
|
|
d. Let nextValue be IteratorValue(next).
|
|
|
|
e. ReturnIfAbrupt(nextValue).
|
|
|
|
f. Let status be Call(adder, set, «nextValue.[[value]]»).
|
|
|
|
g. If status is an abrupt completion, return IteratorClose(iter, status).
|
|
|
|
|
2017-09-08 00:17:05 +02:00
|
|
|
features: [Symbol.iterator]
|
2015-05-19 18:48:52 +02:00
|
|
|
---*/
|
|
|
|
|
|
|
|
var count = 0;
|
|
|
|
var iterable = {};
|
|
|
|
iterable[Symbol.iterator] = function() {
|
|
|
|
return {
|
|
|
|
next: function() {
|
2018-02-15 21:34:45 +01:00
|
|
|
return {
|
|
|
|
value: null,
|
|
|
|
done: false
|
|
|
|
};
|
2015-05-19 18:48:52 +02:00
|
|
|
},
|
|
|
|
return: function() {
|
|
|
|
count += 1;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
2018-02-15 21:34:45 +01:00
|
|
|
Set.prototype.add = function() {
|
|
|
|
throw new Error();
|
|
|
|
}
|
2015-05-19 18:48:52 +02:00
|
|
|
|
2015-05-26 17:52:52 +02:00
|
|
|
assert.throws(Error, function() {
|
|
|
|
new Set(iterable);
|
|
|
|
});
|
2015-05-19 18:48:52 +02:00
|
|
|
|
|
|
|
assert.sameValue(
|
|
|
|
count, 1, "The iterator is closed when `Set.prototype.add` throws an error."
|
|
|
|
);
|