From 26a029d407be480d791972afb5975cf62c9360a6 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 02:47:55 +0200 Subject: Adding upstream version 124.0.1. Signed-off-by: Daniel Baumann --- .../collections/WeakMap-constructor-iterable.js | 28 ++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 js/src/jit-test/tests/collections/WeakMap-constructor-iterable.js (limited to 'js/src/jit-test/tests/collections/WeakMap-constructor-iterable.js') diff --git a/js/src/jit-test/tests/collections/WeakMap-constructor-iterable.js b/js/src/jit-test/tests/collections/WeakMap-constructor-iterable.js new file mode 100644 index 0000000000..f5eac8e30d --- /dev/null +++ b/js/src/jit-test/tests/collections/WeakMap-constructor-iterable.js @@ -0,0 +1,28 @@ +// The argument to WeakMap can be a iterable object. + +load(libdir + "iteration.js"); + +var k1 = {}; +var v1 = 42; +var k2 = {}; +var v2 = 43; +var k3 = {}; + +var done = false; + +var iterable = {}; +iterable[Symbol.iterator] = function*() { + yield [k1, v1]; + yield [k2, v2]; + done = true; +}; +var m = new WeakMap(iterable); + +assertEq(done, true); // the constructor consumes the argument +assertEq(m.has(k1), true); +assertEq(m.has(k2), true); +assertEq(m.has(k3), false); +assertEq(m.get(k1), v1); +assertEq(m.get(k2), v2); +assertEq(m.get(k3), undefined); + -- cgit v1.2.3