mirror of https://github.com/tc39/test262.git
37 lines
720 B
JavaScript
37 lines
720 B
JavaScript
|
// Copyright (C) 2015 the V8 project authors. All rights reserved.
|
||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||
|
|
||
|
/*---
|
||
|
description: Set entry removal and re-insertion during traversal using for..of
|
||
|
info: >
|
||
|
Entries removed from a Set instance during traversal should be visited if
|
||
|
they are re-inserted prior to iterator exhaustion.
|
||
|
es6id: 13.6.4
|
||
|
features: [Set]
|
||
|
---*/
|
||
|
|
||
|
var set = new Set();
|
||
|
var iterationCount = 0;
|
||
|
|
||
|
var first = 0;
|
||
|
var second = 1;
|
||
|
|
||
|
set.add(0);
|
||
|
set.add(1);
|
||
|
|
||
|
for (var x of set) {
|
||
|
assert.sameValue(x, first);
|
||
|
|
||
|
first = second;
|
||
|
second = null;
|
||
|
|
||
|
if (first !== null) {
|
||
|
set.delete(1);
|
||
|
set.add(1);
|
||
|
}
|
||
|
|
||
|
iterationCount += 1;
|
||
|
}
|
||
|
|
||
|
assert.sameValue(iterationCount, 2);
|