From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- js/src/tests/non262/Set/is-disjoint-from.js | 63 +++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 js/src/tests/non262/Set/is-disjoint-from.js (limited to 'js/src/tests/non262/Set/is-disjoint-from.js') diff --git a/js/src/tests/non262/Set/is-disjoint-from.js b/js/src/tests/non262/Set/is-disjoint-from.js new file mode 100644 index 0000000000..0209f637fc --- /dev/null +++ b/js/src/tests/non262/Set/is-disjoint-from.js @@ -0,0 +1,63 @@ +/* + * Any copyright is dedicated to the Public Domain. + * https://creativecommons.org/publicdomain/zero/1.0/ + */ + +if (typeof getBuildConfiguration === "undefined") { + var getBuildConfiguration = SpecialPowers.Cu.getJSTestingFunctions().getBuildConfiguration; +} + +if (typeof getRealmConfiguration === "undefined") { + var getRealmConfiguration = SpecialPowers.Cu.getJSTestingFunctions().getRealmConfiguration; +} + +if (getBuildConfiguration()['new-set-methods'] && getRealmConfiguration().enableNewSetMethods) { + + assertEq(typeof Set.prototype.isDisjointFrom, 'function'); + assertEq(Set.prototype.isDisjointFrom.length, 1); + assertEq(Set.prototype.isDisjointFrom.name, 'isDisjointFrom'); + + assertEq(new Set([1, true, null]).isDisjointFrom(new Set()), true); + assertEq(new Set([1, true, null]).isDisjointFrom([1, true, null]), false); + assertEq(new Set([1, 2, 3]).isDisjointFrom([2, 3, 4]), false); + assertEq(new Set([1, 2, 3]).isDisjointFrom([4]), true); + // Works when the argument is a custom iterable which follows the Symbol.iterator protocol + assertEq(new Set([1, 2, 3]).isDisjointFrom(makeArrayIteratorWithHasMethod([3, 4])), false); + assertEq(new Set(['a']).isDisjointFrom('abc'), false); + + // Works when the `this` is a custom iterable which follows the Symbol.iterator protocol + assertEq(Set.prototype.isDisjointFrom.call(makeArrayIteratorWithHasMethod([1, 2, 3, 3, 2]), [4, 5, 6]), true); + + // Does not modify the original set object + const set = new Set([1]); + assertEq(set.isDisjointFrom([2]) !== set, true); + + // Argument must be iterable + assertThrowsInstanceOf(function () { + const set = new Set(); + set.isDisjointFrom(); + }, TypeError); + for (const arg of [null, {}, true, 1, undefined, NaN, Symbol()]) { + assertThrowsInstanceOf(function () { + const set = new Set(); + set.isDisjointFrom(arg); + }, TypeError); + } + + // `this` must be an Object + for (const arg of [null, undefined, Symbol()]) { + assertThrowsInstanceOf(function () { + Set.prototype.isDisjointFrom.call(arg, []); + }, TypeError); + } + + // `this` must be iterable + assertThrowsInstanceOf(function () { + Set.prototype.isDisjointFrom.call({}, []); + }, TypeError); +} else { + assertEq(typeof Set.prototype.isDisjointFrom, 'undefined'); +} + +if (typeof reportCompare === "function") + reportCompare(true, true); -- cgit v1.2.3