/* 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/. */ "use strict"; // In safe mode, PKCS#11 modules should not be loaded. This test tests this by // simulating starting in safe mode and then attempting to load a module. add_task(async function run_test() { do_get_profile(); Services.fog.initializeFOG(); // Simulate starting in safe mode. let xulRuntime = { inSafeMode: true, logConsoleErrors: true, OS: "XPCShell", XPCOMABI: "noarch-spidermonkey", invalidateCachesOnRestart: function invalidateCachesOnRestart() { // Do nothing }, QueryInterface: ChromeUtils.generateQI(["nsIXULRuntime"]), }; let xulRuntimeFactory = { createInstance(iid) { return xulRuntime.QueryInterface(iid); }, }; let registrar = Components.manager.QueryInterface(Ci.nsIComponentRegistrar); const XULRUNTIME_CONTRACTID = "@mozilla.org/xre/runtime;1"; const XULRUNTIME_CID = Components.ID( "{f0f0b230-5525-4127-98dc-7bca39059e70}" ); registrar.registerFactory( XULRUNTIME_CID, "XULRuntime", XULRUNTIME_CONTRACTID, xulRuntimeFactory ); // When starting in safe mode, the test module should fail to load. let pkcs11ModuleDB = Cc["@mozilla.org/security/pkcs11moduledb;1"].getService( Ci.nsIPKCS11ModuleDB ); let libraryName = ctypes.libraryName("pkcs11testmodule"); let libraryFile = Services.dirsvc.get("CurWorkD", Ci.nsIFile); libraryFile.append("pkcs11testmodule"); libraryFile.append(libraryName); ok(libraryFile.exists(), "The pkcs11testmodule file should exist"); let caughtException = false; try { await pkcs11ModuleDB.addModule( "PKCS11 Test Module", libraryFile.path, 0, 0 ); } catch (e) { caughtException = true; ok(/NS_ERROR_FAILURE/.test(e), "expecting NS_ERROR_FAILURE"); } ok(caughtException, "addModule should throw when in safe mode"); // Though we loaded in safe mode, no NSS initialization fallbacks should have been used. ok(!Glean.nss.initializationFallbacks.READ_ONLY.testGetValue()); ok(!Glean.nss.initializationFallbacks.RENAME_MODULE_DB.testGetValue()); ok( !Glean.nss.initializationFallbacks.RENAME_MODULE_DB_READ_ONLY.testGetValue() ); ok(!Glean.nss.initializationFallbacks.NO_DB_INIT.testGetValue()); });