summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/collections/WeakMap-constructor-set.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /js/src/jit-test/tests/collections/WeakMap-constructor-set.js
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jit-test/tests/collections/WeakMap-constructor-set.js')
-rw-r--r--js/src/jit-test/tests/collections/WeakMap-constructor-set.js199
1 files changed, 199 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/collections/WeakMap-constructor-set.js b/js/src/jit-test/tests/collections/WeakMap-constructor-set.js
new file mode 100644
index 0000000000..4026f824c3
--- /dev/null
+++ b/js/src/jit-test/tests/collections/WeakMap-constructor-set.js
@@ -0,0 +1,199 @@
+load(libdir + "asserts.js");
+load(libdir + "iteration.js");
+
+var k1 = {};
+var v1 = 42;
+var k2 = {};
+var v2 = 42;
+var k3 = {};
+var v3 = 43;
+var k4 = {};
+var v4 = 44;
+
+function test_patched() {
+ let orig = WeakMap.prototype.set;
+
+ // If adder is modified, constructor should call it.
+ var called = false;
+
+ WeakMap.prototype.set = function(k, v) {
+ assertEq(k, k1);
+ assertEq(v, v1);
+ orig.call(this, k2, v2);
+ called = true;
+ };
+
+ var arr = [[k1, v1]];
+
+ var m = new WeakMap(arr);
+
+ assertEq(called, true);
+ assertEq(m.has(k1), false);
+ assertEq(m.has(k2), true);
+ assertEq(m.get(k1), undefined);
+ assertEq(m.get(k2), v2);
+
+ WeakMap.prototype.set = orig;
+}
+
+function test_proxy1() {
+ let orig = WeakMap.prototype.set;
+
+ // If adder is modified, constructor should call it.
+ var called = false;
+
+ WeakMap.prototype.set = new Proxy(function(k, v) {
+ assertEq(k, k1);
+ assertEq(v, v1);
+ orig.call(this, k2, v2);
+ called = true;
+ }, {});
+
+ var arr = [[k1, v1]];
+
+ var m = new WeakMap(arr);
+
+ assertEq(called, true);
+ assertEq(m.has(k1), false);
+ assertEq(m.has(k2), true);
+ assertEq(m.get(k1), undefined);
+ assertEq(m.get(k2), v2);
+
+ WeakMap.prototype.set = orig;
+}
+
+function test_proxy2() {
+ let orig = WeakMap.prototype.set;
+
+ // If adder is modified, constructor should call it.
+ var called = false;
+
+ WeakMap.prototype.set = new Proxy(function() {
+ }, {
+ apply: function(target, that, args) {
+ var [k, v] = args;
+ assertEq(k, k1);
+ assertEq(v, v1);
+ orig.call(that, k2, v2);
+ called = true;
+ }
+ });
+
+ var arr = [[k1, v1]];
+
+ var m = new WeakMap(arr);
+
+ assertEq(called, true);
+ assertEq(m.has(k1), false);
+ assertEq(m.has(k2), true);
+ assertEq(m.get(k1), undefined);
+ assertEq(m.get(k2), v2);
+
+ WeakMap.prototype.set = orig;
+}
+
+function test_change1() {
+ let orig = WeakMap.prototype.set;
+
+ // Change to adder in GetIterator(..) call should be ignored.
+ var called = false;
+ var modified = false;
+
+ var arr = [[k1, v1]];
+
+ var proxy_arr = new Proxy(arr, {
+ get: function(target, name) {
+ if (name == Symbol.iterator) {
+ modified = true;
+ WeakMap.prototype.set = function() {
+ called = true;
+ };
+ }
+ return target[name];
+ }
+ });
+
+ var m = new WeakMap(proxy_arr);
+
+ assertEq(modified, true);
+ assertEq(called, false);
+ assertEq(m.has(k1), true);
+ assertEq(m.has(k2), false);
+ assertEq(m.get(k1), v1);
+ assertEq(m.get(k2), undefined);
+
+ WeakMap.prototype.set = orig;
+}
+
+function test_change2() {
+ let orig = WeakMap.prototype.set;
+
+ // Change to adder in adder(...) call should be ignored.
+ var called = false;
+ var count = 0;
+
+ WeakMap.prototype.set = function(k, v) {
+ if (count == 0) {
+ assertEq(k, k1);
+ assertEq(v, v1);
+ orig.call(this, k3, v3);
+ WeakMap.prototype.set = function() {
+ called = true;
+ };
+ count = 1;
+ } else {
+ assertEq(k, k2);
+ assertEq(v, v2);
+ orig.call(this, k4, v4);
+ count = 2;
+ }
+ };
+
+ var arr = [[k1, v1], [k2, v2]];
+
+ var m = new WeakMap(arr);
+
+ assertEq(called, false);
+ assertEq(count, 2);
+ assertEq(m.has(k1), false);
+ assertEq(m.has(k2), false);
+ assertEq(m.has(k3), true);
+ assertEq(m.has(k4), true);
+ assertEq(m.get(k1), undefined);
+ assertEq(m.get(k2), undefined);
+ assertEq(m.get(k3), v3);
+ assertEq(m.get(k4), v4);
+
+ WeakMap.prototype.set = orig;
+}
+
+function test_error() {
+ let orig = WeakMap.prototype.set;
+
+ var arr = [[k1, v1]];
+
+ // WeakMap should throw TypeError if adder is not callable.
+ WeakMap.prototype.set = null;
+ assertThrowsInstanceOf(() => new WeakMap(arr), TypeError);
+ WeakMap.prototype.set = {};
+ assertThrowsInstanceOf(() => new WeakMap(arr), TypeError);
+
+ // WeakMap should propagate error thrown by adder.
+ WeakMap.prototype.set = function() {
+ throw SyntaxError();
+ };
+ assertThrowsInstanceOf(() => new WeakMap(arr), SyntaxError);
+
+ WeakMap.prototype.set = orig;
+}
+
+function test() {
+ test_patched();
+ test_proxy1();
+ test_proxy2();
+ test_change1();
+ test_change2();
+ test_error();
+}
+
+test();