summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/Iterator/prototype/flatMap/iterable-to-iterator-fallback.js
blob: 34d870c82fa69d27c19fea753d91dbca0f155262 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
// |reftest| shell-option(--enable-iterator-helpers) skip-if(!this.hasOwnProperty('Iterator')||!xulRuntime.shell) -- iterator-helpers is not enabled unconditionally, requires shell-options
// Copyright (C) 2023 Michael Ficarra. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-iteratorprototype.flatMap
description: >
  Iterator.prototype.flatMap falls back to treating mapper return values as iterators if the Symbol.iterator property is null/undefined
info: |
  %Iterator.prototype%.flatMap ( mapper )

  5.b.vi. Let innerIterator be Completion(GetIteratorFlattenable(mapped)).

includes: [compareArray.js]
features: [iterator-helpers]
flags: []
---*/

function* g() {
  yield 0;
}

function* h() {
  yield 0;
  yield 1;
  yield 2;
}

let iter = g().flatMap(v => {
  let n = h();
  return {
    [Symbol.iterator]: 0,
    next: () => n.next(),
  };
});

assert.throws(TypeError, function () {
  iter.next();
});

iter = g().flatMap(v => {
  let n = h();
  return {
    [Symbol.iterator]: null,
    next: () => n.next(),
  };
});

assert.compareArray(Array.from(iter), [0, 1, 2]);

iter = g().flatMap(v => {
  let n = h();
  return {
    [Symbol.iterator]: undefined,
    next: () => n.next(),
  };
});

assert.compareArray(Array.from(iter), [0, 1, 2]);

reportCompare(0, 0);