From 26a029d407be480d791972afb5975cf62c9360a6 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 02:47:55 +0200 Subject: Adding upstream version 124.0.1. Signed-off-by: Daniel Baumann --- js/src/tests/non262/iterable/regress-341815.js | 83 ++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 js/src/tests/non262/iterable/regress-341815.js (limited to 'js/src/tests/non262/iterable/regress-341815.js') diff --git a/js/src/tests/non262/iterable/regress-341815.js b/js/src/tests/non262/iterable/regress-341815.js new file mode 100644 index 0000000000..cd5d9c2b12 --- /dev/null +++ b/js/src/tests/non262/iterable/regress-341815.js @@ -0,0 +1,83 @@ +// |reftest| skip -- bug xxx - fails to dismiss alert +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* 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/. */ + +//----------------------------------------------------------------------------- +var BUGNUMBER = 341815; +var summary = 'Close hook crash'; +var actual = 'No Crash'; +var expect = 'No Crash'; + +var ialert = 0; +//----------------------------------------------------------------------------- +//test(); +//----------------------------------------------------------------------------- + +function test() +{ + printBugNumber(BUGNUMBER); + printStatus (summary); + + var globalToPokeGC = {}; + + function make_iterator() + { + function* generator() { + try { + yield 0; + } finally { + make_iterator(); + } + } + generator().next(); + globalToPokeGC = {}; + if (typeof alert != 'undefined') + { + alert(++ialert); + } + } + + make_iterator(); + + for (var i = 0; i != 50000; ++i) { + var x = {}; + } + + print('done'); + + setTimeout('checkTest()', 10000); +} + +function init() +{ + // give the dialog closer time to register + setTimeout('test()', 5000); +} + +var lastialert = 0; + +function checkTest() +{ + // this function is used to check if there + // additional alerts are still being fired + // in order to prevent the test from completing + // until all alerts have finished. + + if (ialert != lastialert) + { + lastialert = ialert; + setTimeout('checkTest()', 10000); + return; + } + + reportCompare(expect, actual, summary); + gDelayTestDriverEnd = false; + jsTestDriverEnd(); +} + +// delay test driver end +gDelayTestDriverEnd = true; + +window.addEventListener("load", init, false); -- cgit v1.2.3