summaryrefslogtreecommitdiffstats
path: root/js/xpconnect/tests/unit/test_import_stack.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /js/xpconnect/tests/unit/test_import_stack.js
parentInitial commit. (diff)
downloadthunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz
thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--js/xpconnect/tests/unit/test_import_stack.js39
1 files changed, 39 insertions, 0 deletions
diff --git a/js/xpconnect/tests/unit/test_import_stack.js b/js/xpconnect/tests/unit/test_import_stack.js
new file mode 100644
index 0000000000..2fa35a7502
--- /dev/null
+++ b/js/xpconnect/tests/unit/test_import_stack.js
@@ -0,0 +1,39 @@
+Services.prefs.setBoolPref("browser.startup.record", true);
+registerCleanupFunction(() => {
+ Services.prefs.clearUserPref("browser.startup.record");
+});
+
+add_task(function test_JSModule() {
+ const URL = "resource://test/import_stack.jsm";
+ ChromeUtils.import(URL);
+ Assert.ok(Cu.getModuleImportStack(URL).includes("test_JSModule"));
+});
+
+add_task(function test_ESModule() {
+ const URL = "resource://test/import_stack.sys.mjs";
+ ChromeUtils.importESModule(URL);
+ Assert.ok(Cu.getModuleImportStack(URL).includes("test_ESModule"));
+});
+
+add_task(function test_ESModule_static_import() {
+ const URL1 = "resource://test/import_stack_static_1.sys.mjs";
+ const URL2 = "resource://test/import_stack_static_2.sys.mjs";
+ const URL3 = "resource://test/import_stack_static_3.sys.mjs";
+ const URL4 = "resource://test/import_stack_static_4.sys.mjs";
+
+ ChromeUtils.importESModule(URL1);
+
+ Assert.ok(Cu.getModuleImportStack(URL1).includes("test_ESModule_static"));
+
+ Assert.ok(Cu.getModuleImportStack(URL2).includes("test_ESModule_static"));
+ Assert.ok(Cu.getModuleImportStack(URL2).includes(URL1));
+
+ Assert.ok(Cu.getModuleImportStack(URL3).includes("test_ESModule_static"));
+ Assert.ok(Cu.getModuleImportStack(URL3).includes(URL1));
+ Assert.ok(Cu.getModuleImportStack(URL3).includes(URL2));
+
+ Assert.ok(Cu.getModuleImportStack(URL4).includes("test_ESModule_static"));
+ Assert.ok(Cu.getModuleImportStack(URL4).includes(URL1));
+ Assert.ok(Cu.getModuleImportStack(URL4).includes(URL2));
+ Assert.ok(Cu.getModuleImportStack(URL4).includes(URL3));
+});