summaryrefslogtreecommitdiffstats
path: root/js/src/tests/non262/BigInt/property-name.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/tests/non262/BigInt/property-name.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/tests/non262/BigInt/property-name.js')
-rw-r--r--js/src/tests/non262/BigInt/property-name.js194
1 files changed, 194 insertions, 0 deletions
diff --git a/js/src/tests/non262/BigInt/property-name.js b/js/src/tests/non262/BigInt/property-name.js
new file mode 100644
index 0000000000..85addd550a
--- /dev/null
+++ b/js/src/tests/non262/BigInt/property-name.js
@@ -0,0 +1,194 @@
+// BigInt literals as property keys.
+{
+ let o = {
+ 0n: "0",
+ 1n: "1",
+
+ // 2**31
+ 2147483647n: "2^31-1",
+ 2147483648n: "2^31",
+ 2147483649n: "2^31+1",
+
+ // 2**32
+ 4294967295n: "2^32-1",
+ 4294967296n: "2^32",
+ 4294967297n: "2^32+1",
+
+ // 2n**63n
+ 9223372036854775807n: "2^63-1",
+ 9223372036854775808n: "2^63",
+ 9223372036854775809n: "2^63+1",
+
+ // 2n**64n
+ 18446744073709551615n: "2^64-1",
+ 18446744073709551616n: "2^64",
+ 18446744073709551617n: "2^64+1",
+ };
+
+ assertEq(o[0], "0");
+ assertEq(o[1], "1");
+
+ assertEq(o[2147483647], "2^31-1");
+ assertEq(o[2147483648], "2^31");
+ assertEq(o[2147483649], "2^31+1");
+
+ assertEq(o[4294967295], "2^32-1");
+ assertEq(o[4294967296], "2^32");
+ assertEq(o[4294967297], "2^32+1");
+
+ assertEq(o["9223372036854775807"], "2^63-1");
+ assertEq(o["9223372036854775808"], "2^63");
+ assertEq(o["9223372036854775809"], "2^63+1");
+
+ assertEq(o["18446744073709551615"], "2^64-1");
+ assertEq(o["18446744073709551616"], "2^64");
+ assertEq(o["18446744073709551617"], "2^64+1");
+}
+
+// With non-decimal different base.
+{
+ let o = {
+ 0b1n: "1",
+ 0o2n: "2",
+ 0x3n: "3",
+ };
+
+ assertEq(o[1], "1");
+ assertEq(o[2], "2");
+ assertEq(o[3], "3");
+}
+
+// With numeric separators.
+{
+ let o = {
+ 1_2_3n: "123",
+ };
+
+ assertEq(o[123], "123");
+}
+
+// BigInt literals as method property names.
+{
+ let o = {
+ 1n() {},
+ *2n() {},
+ async 3n() {},
+ async* 4n() {},
+ get 5n() {},
+ set 6n(x) {},
+ };
+
+ assertEqArray(Object.getOwnPropertyNames(o), [
+ "1", "2", "3", "4", "5", "6",
+ ]);
+
+ assertEq(o[1].name, "1");
+ assertEq(o[2].name, "2");
+ assertEq(o[3].name, "3");
+ assertEq(o[4].name, "4");
+ assertEq(Object.getOwnPropertyDescriptor(o, 5).get.name, "get 5");
+ assertEq(Object.getOwnPropertyDescriptor(o, 6).set.name, "set 6");
+}
+
+// BigInt literals as class method property names.
+{
+ class C {
+ 1n() {}
+ *2n() {}
+ async 3n() {}
+ async* 4n() {}
+ get 5n() {}
+ set 6n(x) {}
+ }
+ let o = C.prototype;
+
+ assertEqArray(Object.getOwnPropertyNames(o), [
+ "1", "2", "3", "4", "5", "6",
+ "constructor",
+ ]);
+
+ assertEq(o[1].name, "1");
+ assertEq(o[2].name, "2");
+ assertEq(o[3].name, "3");
+ assertEq(o[4].name, "4");
+ assertEq(Object.getOwnPropertyDescriptor(o, 5).get.name, "get 5");
+ assertEq(Object.getOwnPropertyDescriptor(o, 6).set.name, "set 6");
+}
+
+// BigInt literals as static class method property names.
+{
+ class C {
+ static 1n() {}
+ static *2n() {}
+ static async 3n() {}
+ static async* 4n() {}
+ static get 5n() {}
+ static set 6n(x) {}
+ }
+ let o = C;
+
+ // NB: Sort names because lazily resolved "length" and "name" properties are
+ // inserted in the wrong order.
+ assertEqArray(Object.getOwnPropertyNames(o).sort(), [
+ "1", "2", "3", "4", "5", "6",
+ "length", "name", "prototype",
+ ]);
+
+ assertEq(o[1].name, "1");
+ assertEq(o[2].name, "2");
+ assertEq(o[3].name, "3");
+ assertEq(o[4].name, "4");
+ assertEq(Object.getOwnPropertyDescriptor(o, 5).get.name, "get 5");
+ assertEq(Object.getOwnPropertyDescriptor(o, 6).set.name, "set 6");
+}
+
+// BigInt literals as class field property names.
+{
+ let o = new class {
+ 1n;
+ 2n = "ok";
+ };
+
+ assertEq(o[1], undefined);
+ assertEq(o[2], "ok");
+}
+
+// In binding destructuring contexts.
+{
+ let {0n: a} = ["ok"];
+ assertEq(a, "ok");
+}
+
+// In binding destructuring contexts with object rest pattern.
+{
+ let {0n: a, ...b} = ["ok", "test"];
+ assertEq(a, "ok");
+ assertEqArray(Object.getOwnPropertyNames(b), ["1"]);
+}
+
+// In assignment destructuring contexts.
+{
+ let a;
+ ({0n: a} = ["ok"]);
+ assertEq(a, "ok");
+}
+
+// In assignment destructuring contexts with object rest pattern.
+{
+ let a, b;
+ ({0n: a, ...b} = ["ok", "test"]);
+ assertEq(a, "ok");
+ assertEqArray(Object.getOwnPropertyNames(b), ["1"]);
+}
+
+// BigInt literals as inferred names.
+{
+ let o = {
+ 0xan: function(){},
+ };
+
+ assertEq(o[10].name, "10");
+}
+
+if (typeof reportCompare === "function")
+ reportCompare(true, true);