/* 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"; add_task(async function test_idle_cleanup() { Services.fog.testResetFOG(); Services.prefs.setBoolPref( "network.cache.shutdown_purge_in_background_task", true ); Services.prefs.setBoolPref("privacy.clearOnShutdown.cache", true); Services.prefs.setBoolPref("privacy.sanitize.sanitizeOnShutdown", true); let dir = Services.dirsvc.get("ProfD", Ci.nsIFile); dir.append("cache2.2021-11-25-08-47-04.purge.bg_rm"); Assert.equal(dir.exists(), false, `Folder ${dir.path} should not exist`); dir.create(Ci.nsIFile.DIRECTORY_TYPE, 0o744); Assert.equal( dir.exists(), true, `Folder ${dir.path} should have been created` ); Services.obs.notifyObservers(null, "idle-daily"); await TestUtils.waitForCondition(() => { return !dir.exists(); }); Assert.equal( dir.exists(), false, `Folder ${dir.path} should have been purged by background task` ); Assert.equal( await Glean.networking.residualCacheFolderCount.testGetValue(), 1 ); Assert.equal( await Glean.networking.residualCacheFolderRemoval.success.testGetValue(), 1 ); Assert.equal( await Glean.networking.residualCacheFolderRemoval.failure.testGetValue(), null ); // Check that telemetry properly detects folders failing to be deleted when readonly // Making folders readonly only works on windows if (AppConstants.platform == "win") { dir.create(Ci.nsIFile.DIRECTORY_TYPE, 0o744); dir.QueryInterface(Ci.nsILocalFileWin).readOnly = true; Services.obs.notifyObservers(null, "idle-daily"); await BrowserTestUtils.waitForCondition(async () => { return ( (await Glean.networking.residualCacheFolderRemoval.failure.testGetValue()) == 1 ); }); Assert.equal( await Glean.networking.residualCacheFolderCount.testGetValue(), 2 ); Assert.equal( await Glean.networking.residualCacheFolderRemoval.success.testGetValue(), 1 ); Assert.equal( await Glean.networking.residualCacheFolderRemoval.failure.testGetValue(), 1 ); dir.QueryInterface(Ci.nsILocalFileWin).readOnly = false; dir.remove(true); } Services.prefs.clearUserPref( "network.cache.shutdown_purge_in_background_task" ); Services.prefs.clearUserPref("privacy.clearOnShutdown.cache"); Services.prefs.clearUserPref("privacy.sanitize.sanitizeOnShutdown"); });