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 --- .../for-inof-coverinitname-destr-assign.js | 55 ++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 js/src/tests/non262/statements/for-inof-coverinitname-destr-assign.js (limited to 'js/src/tests/non262/statements/for-inof-coverinitname-destr-assign.js') diff --git a/js/src/tests/non262/statements/for-inof-coverinitname-destr-assign.js b/js/src/tests/non262/statements/for-inof-coverinitname-destr-assign.js new file mode 100644 index 0000000000..ba9e409599 --- /dev/null +++ b/js/src/tests/non262/statements/for-inof-coverinitname-destr-assign.js @@ -0,0 +1,55 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +const defaultValue = "default-value"; +const unreachable = () => { throw "unreachable"; }; + +// for-in statement, object destructuring. +var forIn; +for ({forIn = defaultValue} in {"": null}); +assertEq(forIn, defaultValue); + +forIn = undefined; +String.prototype.forIn = defaultValue; +for ({forIn = unreachable()} in {"": null}); +delete String.prototype.forIn; +assertEq(forIn, defaultValue); + +// for-in statement, array destructuring. +forIn = undefined; +for ([forIn = defaultValue] in {"": null}); +assertEq(forIn, defaultValue); + +forIn = undefined; +for ([forIn = unreachable()] in {"ABC": null}); +assertEq(forIn, "A"); + + +// for-of statement, object destructuring. +var forOf; +for ({forOf = defaultValue} of [{}]); +assertEq(forOf, defaultValue); + +forOf = undefined; +for ({forOf = unreachable()} of [{forOf: defaultValue}]); +assertEq(forOf, defaultValue); + +// for-of statement, array destructuring. +forOf = undefined; +for ([forOf = defaultValue] of [[]]); +assertEq(forOf, defaultValue); + +forOf = undefined; +for ([forOf = unreachable()] of [[defaultValue]]); +assertEq(forOf, defaultValue); + + +// for-statement, object destructuring. +assertThrowsInstanceOf(() => eval(` + for ({invalid = 0};;); +`), SyntaxError); + + +if (typeof reportCompare === "function") + reportCompare(true, true); -- cgit v1.2.3