Thu, 22 Jan 2015 13:21:57 +0100
Incorporate requested changes from Mozilla in review:
https://bugzilla.mozilla.org/show_bug.cgi?id=1123480#c6
1 // Removing many Set entries does not cause a live iterator to skip any of the
2 // entries that were not removed. (Compacting a Set must not be observable to
3 // script.)
5 load(libdir + "iteration.js");
7 var set = Set();
8 for (var i = 0; i < 32; i++)
9 set.add(i);
10 var iter = set[std_iterator]();
11 assertIteratorNext(iter, 0);
12 for (var i = 0; i < 30; i++)
13 set.delete(i);
14 assertEq(set.size, 2);
15 for (var i = 32; i < 100; i++)
16 set.add(i); // eventually triggers compaction
18 for (var i = 30; i < 100; i++)
19 assertIteratorNext(iter, i);
20 assertIteratorDone(iter, undefined);