diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
commit | 2aa4a82499d4becd2284cdb482213d541b8804dd (patch) | |
tree | b80bf8bf13c3766139fbacc530efd0dd9d54394c /js/src/jsapi-tests/testSlowScript.cpp | |
parent | Initial commit. (diff) | |
download | firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip |
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jsapi-tests/testSlowScript.cpp')
-rw-r--r-- | js/src/jsapi-tests/testSlowScript.cpp | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/js/src/jsapi-tests/testSlowScript.cpp b/js/src/jsapi-tests/testSlowScript.cpp new file mode 100644 index 0000000000..34c736b957 --- /dev/null +++ b/js/src/jsapi-tests/testSlowScript.cpp @@ -0,0 +1,87 @@ +/* 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/. */ + +#include "jsapi-tests/tests.h" + +static bool InterruptCallback(JSContext* cx) { return false; } + +static unsigned sRemain; + +static bool RequestInterruptCallback(JSContext* cx, unsigned argc, jsval* vp) { + JS::CallArgs args = JS::CallArgsFromVp(argc, vp); + if (!sRemain--) { + JS_RequestInterruptCallback(cx); + } + args.rval().setUndefined(); + return true; +} + +BEGIN_TEST(testSlowScript) { + JS_AddInterruptCallback(cx, InterruptCallback); + JS_DefineFunction(cx, global, "requestInterruptCallback", + RequestInterruptCallback, 0, 0); + + test( + "while (true)" + " for (i in [0,0,0,0])" + " requestInterruptCallback();"); + + test( + "while (true)" + " for (i in [0,0,0,0])" + " for (j in [0,0,0,0])" + " requestInterruptCallback();"); + + test( + "while (true)" + " for (i in [0,0,0,0])" + " for (j in [0,0,0,0])" + " for (k in [0,0,0,0])" + " requestInterruptCallback();"); + + test( + "function f() { while (true) yield requestInterruptCallback() }" + "for (i in f()) ;"); + + test( + "function f() { while (true) yield 1 }" + "for (i in f())" + " requestInterruptCallback();"); + + test( + "(function() {" + " while (true)" + " let (x = 1) { eval('requestInterruptCallback()'); }" + "})()"); + + return true; +} + +bool test(const char* bytes) { + jsval v; + + JS_SetOptions(cx, JS_GetOptions(cx) & + ~(JSOPTION_METHODJIT | JSOPTION_METHODJIT_ALWAYS)); + sRemain = 0; + CHECK(!evaluate(bytes, __FILE__, __LINE__, &v)); + CHECK(!JS_IsExceptionPending(cx)); + + sRemain = 1000; + CHECK(!evaluate(bytes, __FILE__, __LINE__, &v)); + CHECK(!JS_IsExceptionPending(cx)); + + JS_SetOptions( + cx, JS_GetOptions(cx) | JSOPTION_METHODJIT | JSOPTION_METHODJIT_ALWAYS); + + sRemain = 0; + CHECK(!evaluate(bytes, __FILE__, __LINE__, &v)); + CHECK(!JS_IsExceptionPending(cx)); + + sRemain = 1000; + CHECK(!evaluate(bytes, __FILE__, __LINE__, &v)); + CHECK(!JS_IsExceptionPending(cx)); + + return true; +} +END_TEST(testSlowScript) |