forked from tc39/test262
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update iteration tests with respect to spec changes
tc39/ecma262#988 changes the iteration protocol such that the "next" method is only loaded from the iterator object once during the prologue of iteration, rather than during each step.
- Loading branch information
Showing
1 changed file
with
22 additions
and
22 deletions.
There are no files selected for viewing
44 changes: 22 additions & 22 deletions
44
test/language/statements/for-of/iterator-next-reference.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,41 +1,41 @@ | ||
// Copyright (C) 2013 the V8 project authors. All rights reserved. | ||
// This code is governed by the BSD license found in the LICENSE file. | ||
/*--- | ||
es6id: 13.6.4.13 S5.c | ||
esid: sec-getiterator | ||
description: > | ||
The iterator's `next` method should be accessed with each iteration as per | ||
the `IteratorStep` abstract operation (7.4.5). | ||
features: [Symbol.iterator] | ||
The iterator's `next` method should be accessed only once with each | ||
iteration as per the `GetIterator` abstract operation (7.4.1). | ||
features: [Symbol.iterator, for-of] | ||
---*/ | ||
|
||
var iterable = {}; | ||
var iterator = {}; | ||
var firstIterResult = { done: false }; | ||
var iterationCount, invocationCount; | ||
var iterationCount = 0; | ||
var loadNextCount = 0; | ||
|
||
iterable[Symbol.iterator] = function() { | ||
return iterator; | ||
}; | ||
|
||
iterator.next = function() { return { value: 45, done: false }; }; | ||
iterationCount = 0; | ||
invocationCount = 0; | ||
function next() { | ||
if (iterationCount) return { done: true }; | ||
return { value: 45, done: false }; | ||
} | ||
Object.defineProperty(iterator, 'next', { | ||
get() { loadNextCount++; return next; }, | ||
configurable: true | ||
}); | ||
|
||
for (var x of iterable) { | ||
assert.sameValue(x, 45); | ||
|
||
iterator.next = function() { | ||
invocationCount++; | ||
|
||
Object.defineProperty(iterator, 'next', { | ||
get: function() { | ||
$ERROR('Should not access the `next` method after iteration ' + | ||
'is complete.'); | ||
} | ||
}); | ||
|
||
return { value: null, done: true }; | ||
}; | ||
Object.defineProperty(iterator, 'next', { | ||
get: function() { | ||
throw new Test262Error( | ||
'Should not access the `next` method after the iteration prologue.'); | ||
} | ||
}); | ||
iterationCount++; | ||
} | ||
assert.sameValue(iterationCount, 1); | ||
assert.sameValue(invocationCount, 1); | ||
assert.sameValue(loadNextCount, 1); |