diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /js/src/tests/non262/Tuple/prototype/toString | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | js/src/tests/non262/Tuple/prototype/toString/length.js | 27 | ||||
-rw-r--r-- | js/src/tests/non262/Tuple/prototype/toString/to-string.js | 21 |
2 files changed, 48 insertions, 0 deletions
diff --git a/js/src/tests/non262/Tuple/prototype/toString/length.js b/js/src/tests/non262/Tuple/prototype/toString/length.js new file mode 100644 index 0000000000..1a12340df3 --- /dev/null +++ b/js/src/tests/non262/Tuple/prototype/toString/length.js @@ -0,0 +1,27 @@ +// |reftest| skip-if(!this.hasOwnProperty("Tuple")) +var desc = Object.getOwnPropertyDescriptor(Tuple.prototype.toString, "length"); +assertEq(desc.value, 0); +assertEq(desc.writable, false); +assertEq(desc.enumerable, false); +assertEq(desc.configurable, true); + + +desc = Object.getOwnPropertyDescriptor(Tuple.prototype.toString, "name"); +assertEq(desc.value, "toString"); +assertEq(desc.writable, false); +assertEq(desc.enumerable, false); +assertEq(desc.configurable, true); + +desc = Object.getOwnPropertyDescriptor(Tuple.prototype, "toString"); +assertEq(desc.writable, true); +assertEq(desc.enumerable, false); +assertEq(desc.configurable, true); + +assertEq(isConstructor(Tuple.prototype.toString), false); + +assertThrowsInstanceOf(() => { + let t = #[1]; + new t.toString(); +}, TypeError, '`let t = #[1]; new t.toString()` throws TypeError'); + +reportCompare(0, 0); diff --git a/js/src/tests/non262/Tuple/prototype/toString/to-string.js b/js/src/tests/non262/Tuple/prototype/toString/to-string.js new file mode 100644 index 0000000000..e600ca78a2 --- /dev/null +++ b/js/src/tests/non262/Tuple/prototype/toString/to-string.js @@ -0,0 +1,21 @@ +// |reftest| skip-if(!this.hasOwnProperty("Tuple")) +/* Step 1 */ +/* toString() should throw on a non-Tuple */ +let method = Tuple.prototype.toString; +assertEq(method.call(#[1,2,3,4,5,6]), "1,2,3,4,5,6"); +assertEq(method.call(Object(#[1,2,3,4,5,6])), "1,2,3,4,5,6"); +assertThrowsInstanceOf(() => method.call("monkeys"), TypeError, + "value of TupleObject must be a Tuple"); + +// Normal case +assertEq(#[].toString(), ""); +assertEq(#[1].toString(), "1"); +assertEq(#[1,2].toString(), "1,2"); + +// if join method isn't callable, Object.toString should be called +Tuple.prototype.join = 7; +var t = #[1,2,3]; +assertEq(t.toString(), "[object Tuple]"); + + +reportCompare(0, 0); |