summaryrefslogtreecommitdiffstats
path: root/browser/modules/test/unit/test_FirefoxBridgeExtensionUtilsNativeManifest.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 01:14:29 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 01:14:29 +0000
commitfbaf0bb26397aa498eb9156f06d5a6fe34dd7dd8 (patch)
tree4c1ccaf5486d4f2009f9a338a98a83e886e29c97 /browser/modules/test/unit/test_FirefoxBridgeExtensionUtilsNativeManifest.js
parentReleasing progress-linux version 124.0.1-1~progress7.99u1. (diff)
downloadfirefox-fbaf0bb26397aa498eb9156f06d5a6fe34dd7dd8.tar.xz
firefox-fbaf0bb26397aa498eb9156f06d5a6fe34dd7dd8.zip
Merging upstream version 125.0.1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'browser/modules/test/unit/test_FirefoxBridgeExtensionUtilsNativeManifest.js')
-rw-r--r--browser/modules/test/unit/test_FirefoxBridgeExtensionUtilsNativeManifest.js222
1 files changed, 222 insertions, 0 deletions
diff --git a/browser/modules/test/unit/test_FirefoxBridgeExtensionUtilsNativeManifest.js b/browser/modules/test/unit/test_FirefoxBridgeExtensionUtilsNativeManifest.js
new file mode 100644
index 0000000000..cef550d705
--- /dev/null
+++ b/browser/modules/test/unit/test_FirefoxBridgeExtensionUtilsNativeManifest.js
@@ -0,0 +1,222 @@
+/* Any copyright is dedicated to the Public Domain.
+http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+const { AppConstants } = ChromeUtils.importESModule(
+ "resource://gre/modules/AppConstants.sys.mjs"
+);
+const { FileUtils } = ChromeUtils.importESModule(
+ "resource://gre/modules/FileUtils.sys.mjs"
+);
+const { FirefoxBridgeExtensionUtils } = ChromeUtils.importESModule(
+ "resource:///modules/FirefoxBridgeExtensionUtils.sys.mjs"
+);
+
+const DUAL_BROWSER_EXTENSION_ORIGIN = ["chrome-extension://fake-origin/"];
+const NATIVE_MESSAGING_HOST_ID = "org.mozilla.firefox_bridge_test";
+
+let dir = FileUtils.getDir("TmpD", ["NativeMessagingHostsTest"]);
+dir.createUnique(Ci.nsIFile.DIRECTORY_TYPE, FileUtils.PERMS_DIRECTORY);
+
+let userDir = dir.clone();
+userDir.append("user");
+userDir.create(Ci.nsIFile.DIRECTORY_TYPE, FileUtils.PERMS_DIRECTORY);
+
+let appDir = dir.clone();
+appDir.append("app");
+appDir.create(Ci.nsIFile.DIRECTORY_TYPE, FileUtils.PERMS_DIRECTORY);
+
+let dirProvider = {
+ getFile(property) {
+ if (property == "Home") {
+ return userDir.clone();
+ } else if (property == "AppData") {
+ return appDir.clone();
+ }
+ return null;
+ },
+};
+
+try {
+ Services.dirsvc.undefine("Home");
+} catch (e) {}
+try {
+ Services.dirsvc.undefine("AppData");
+} catch (e) {}
+Services.dirsvc.registerProvider(dirProvider);
+
+registerCleanupFunction(() => {
+ Services.dirsvc.unregisterProvider(dirProvider);
+ dir.remove(true);
+});
+
+const USER_TEST_PATH = PathUtils.join(userDir.path, "manifestDir");
+
+let binFile = null;
+add_setup(async function () {
+ binFile = Services.dirsvc.get("XREExeF", Ci.nsIFile).parent.clone();
+ if (AppConstants.platform == "win") {
+ binFile.append("nmhproxy.exe");
+ } else if (AppConstants.platform == "macosx") {
+ binFile.append("nmhproxy");
+ } else {
+ throw new Error("Unsupported platform");
+ }
+});
+
+function getExpectedOutput() {
+ return {
+ name: NATIVE_MESSAGING_HOST_ID,
+ description: "Firefox Native Messaging Host",
+ path: binFile.path,
+ type: "stdio",
+ allowed_origins: DUAL_BROWSER_EXTENSION_ORIGIN,
+ };
+}
+
+add_task(async function test_maybeWriteManifestFiles() {
+ await FirefoxBridgeExtensionUtils.maybeWriteManifestFiles(
+ USER_TEST_PATH,
+ NATIVE_MESSAGING_HOST_ID,
+ DUAL_BROWSER_EXTENSION_ORIGIN
+ );
+ let expectedOutput = JSON.stringify(getExpectedOutput());
+ let nmhManifestFilePath = PathUtils.join(
+ USER_TEST_PATH,
+ `${NATIVE_MESSAGING_HOST_ID}.json`
+ );
+ let nmhManifestFileContent = await IOUtils.readUTF8(nmhManifestFilePath);
+ await IOUtils.remove(nmhManifestFilePath);
+ Assert.equal(nmhManifestFileContent, expectedOutput);
+});
+
+add_task(async function test_maybeWriteManifestFilesIncorrect() {
+ let nmhManifestFile = await IOUtils.getFile(
+ USER_TEST_PATH,
+ `${NATIVE_MESSAGING_HOST_ID}.json`
+ );
+
+ let incorrectInput = {
+ name: NATIVE_MESSAGING_HOST_ID,
+ description: "Manifest with unexpected description",
+ path: binFile.path,
+ type: "stdio",
+ allowed_origins: DUAL_BROWSER_EXTENSION_ORIGIN,
+ };
+ await IOUtils.writeJSON(nmhManifestFile.path, incorrectInput);
+
+ // Write correct JSON to the file and check to make sure it matches
+ // the expected output
+ await FirefoxBridgeExtensionUtils.maybeWriteManifestFiles(
+ USER_TEST_PATH,
+ NATIVE_MESSAGING_HOST_ID,
+ DUAL_BROWSER_EXTENSION_ORIGIN
+ );
+ let expectedOutput = JSON.stringify(getExpectedOutput());
+
+ let nmhManifestFilePath = PathUtils.join(
+ USER_TEST_PATH,
+ `${NATIVE_MESSAGING_HOST_ID}.json`
+ );
+ let nmhManifestFileContent = await IOUtils.readUTF8(nmhManifestFilePath);
+ await IOUtils.remove(nmhManifestFilePath);
+ Assert.equal(nmhManifestFileContent, expectedOutput);
+});
+
+add_task(async function test_maybeWriteManifestFilesAlreadyExists() {
+ // Write file and confirm it exists
+ await FirefoxBridgeExtensionUtils.maybeWriteManifestFiles(
+ USER_TEST_PATH,
+ NATIVE_MESSAGING_HOST_ID,
+ DUAL_BROWSER_EXTENSION_ORIGIN
+ );
+ let nmhManifestFile = await IOUtils.getFile(
+ USER_TEST_PATH,
+ `${NATIVE_MESSAGING_HOST_ID}.json`
+ );
+
+ // Modify file modificatiomn time to be older than the write time
+ let oldModificationTime = Date.now() - 1000000;
+ let setModificationTime = await IOUtils.setModificationTime(
+ nmhManifestFile.path,
+ oldModificationTime
+ );
+ Assert.equal(oldModificationTime, setModificationTime);
+
+ // Call function which writes correct JSON to the file and make sure
+ // the modification time is the same, meaning we haven't written anything
+ await FirefoxBridgeExtensionUtils.maybeWriteManifestFiles(
+ USER_TEST_PATH,
+ NATIVE_MESSAGING_HOST_ID,
+ DUAL_BROWSER_EXTENSION_ORIGIN
+ );
+ let stat = await IOUtils.stat(nmhManifestFile.path);
+ await IOUtils.remove(nmhManifestFile.path);
+ Assert.equal(stat.lastModified, oldModificationTime);
+});
+
+add_task(async function test_maybeWriteManifestFilesDirDoesNotExist() {
+ let testDir = dir.clone();
+ // This folder does not exist, so we want to make sure it's created
+ testDir.append("dirDoesNotExist");
+ await FirefoxBridgeExtensionUtils.maybeWriteManifestFiles(
+ testDir.path,
+ NATIVE_MESSAGING_HOST_ID,
+ DUAL_BROWSER_EXTENSION_ORIGIN
+ );
+
+ ok(await IOUtils.exists(testDir.path));
+ ok(
+ await IOUtils.exists(
+ PathUtils.join(testDir.path, `${NATIVE_MESSAGING_HOST_ID}.json`)
+ )
+ );
+ await IOUtils.remove(testDir.path, { recursive: true });
+});
+
+add_task(async function test_ensureRegistered() {
+ let expectedJSONDirPath = null;
+ let nativeHostId = "org.mozilla.firefox_bridge_nmh";
+ if (AppConstants.NIGHTLY_BUILD) {
+ nativeHostId = "org.mozilla.firefox_bridge_nmh_nightly";
+ } else if (AppConstants.MOZ_DEV_EDITION) {
+ nativeHostId = "org.mozilla.firefox_bridge_nmh_dev";
+ } else if (AppConstants.IS_ESR) {
+ nativeHostId = "org.mozilla.firefox_bridge_nmh_esr";
+ }
+
+ if (AppConstants.platform == "macosx") {
+ expectedJSONDirPath = PathUtils.joinRelative(
+ userDir.path,
+ "Library/Application Support/Google/Chrome/NativeMessagingHosts/"
+ );
+ } else if (AppConstants.platform == "win") {
+ expectedJSONDirPath = PathUtils.joinRelative(
+ appDir.path,
+ "Mozilla\\Firefox"
+ );
+ } else {
+ throw new Error("Unsupported platform");
+ }
+
+ ok(!(await IOUtils.exists(expectedJSONDirPath)));
+ let expectedJSONPath = PathUtils.join(
+ expectedJSONDirPath,
+ `${nativeHostId}.json`
+ );
+
+ await FirefoxBridgeExtensionUtils.ensureRegistered();
+ let realOutput = {
+ name: nativeHostId,
+ description: "Firefox Native Messaging Host",
+ path: binFile.path,
+ type: "stdio",
+ allowed_origins: FirefoxBridgeExtensionUtils.getExtensionOrigins(),
+ };
+
+ let expectedOutput = JSON.stringify(realOutput);
+ let JSONContent = await IOUtils.readUTF8(expectedJSONPath);
+ await IOUtils.remove(expectedJSONPath);
+ Assert.equal(JSONContent, expectedOutput);
+});