/** * Any copyright is dedicated to the Public Domain. * http://creativecommons.org/publicdomain/zero/1.0/ */ const { PrincipalUtils } = ChromeUtils.importESModule( "resource://testing-common/dom/quota/test/modules/PrincipalUtils.sys.mjs" ); const { QuotaUtils } = ChromeUtils.importESModule( "resource://testing-common/dom/quota/test/modules/QuotaUtils.sys.mjs" ); const { TestUtils } = ChromeUtils.importESModule( "resource://testing-common/TestUtils.sys.mjs" ); add_task( { pref_set: [ ["dom.storage.requestFinalization.pauseOnDOMFileThreadMs", 2000], ], }, async function testSteps() { const principal = PrincipalUtils.createPrincipal("https://example.com"); info("Testing origin clearing requested after starting database work"); // We need some existing data on disk, otherwise the preloading won't create // a datastore in memory that holds a directory lock. info("Clearing"); { const request = Services.qms.clear(); await QuotaUtils.requestFinished(request); } info("Installing package"); installPackage("somedata_profile"); info("Preloading"); await Services.domStorageManager.preload(principal); info("Starting database opening"); const openPromise = Services.domStorageManager.preload(principal); info("Waiting for request finalization to start"); await TestUtils.topicObserved("LocalStorage::RequestFinalizationStarted"); info("Starting origin clearing"); const clearPromise = (async function () { const request = Services.qms.clearStoragesForPrincipal(principal); const promise = QuotaUtils.requestFinished(request); return promise; })(); info("Waiting for database to finish opening"); try { await openPromise; ok(false, "Should have thrown"); } catch (e) { ok(true, "Should have thrown"); Assert.strictEqual( e.result, Cr.NS_ERROR_ABORT, "Threw right result code" ); } info("Waiting for origin to finish clearing"); await clearPromise; const isPreloaded = await Services.domStorageManager.isPreloaded(principal); Assert.equal(isPreloaded, false, "Datastore is not preloaded"); } ); add_task( { pref_set: [ ["dom.storage.requestFinalization.pauseOnDOMFileThreadMs", 2000], ], }, async function testStepsChild() { const principal = PrincipalUtils.createPrincipal("https://example.com"); info("Clearing"); { const request = Services.qms.clear(); await QuotaUtils.requestFinished(request); } info("Installing package"); installPackage("somedata_profile"); info("Preloading"); await Services.domStorageManager.preload(principal); info("Starting database opening"); const openPromise = run_test_in_child("slowRequestFinalization_child.js"); info("Waiting for request finalization to start"); await TestUtils.topicObserved("LocalStorage::RequestFinalizationStarted"); info("Starting origin clearing"); const clearPromise = (async function () { const request = Services.qms.clearStoragesForPrincipal(principal); const promise = QuotaUtils.requestFinished(request); return promise; })(); info("Waiting for database to finish opening"); // The abort error is checked in the child test, so this shouldn't throw. // We just wait for the child test to finish here. await openPromise; info("Waiting for origin to finish clearing"); await clearPromise; } );