summaryrefslogtreecommitdiffstats
path: root/dom/quota/test/marionette
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /dom/quota/test/marionette
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/quota/test/marionette')
-rw-r--r--dom/quota/test/marionette/dummy.py0
-rw-r--r--dom/quota/test/marionette/manifest.toml5
-rw-r--r--dom/quota/test/marionette/quota_test_case.py113
3 files changed, 118 insertions, 0 deletions
diff --git a/dom/quota/test/marionette/dummy.py b/dom/quota/test/marionette/dummy.py
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/dom/quota/test/marionette/dummy.py
diff --git a/dom/quota/test/marionette/manifest.toml b/dom/quota/test/marionette/manifest.toml
new file mode 100644
index 0000000000..de02cdd541
--- /dev/null
+++ b/dom/quota/test/marionette/manifest.toml
@@ -0,0 +1,5 @@
+[DEFAULT]
+support-files = ["quota_test_case.py"]
+
+["dummy.py"]
+skip-if = ["true"]
diff --git a/dom/quota/test/marionette/quota_test_case.py b/dom/quota/test/marionette/quota_test_case.py
new file mode 100644
index 0000000000..c31edcaaf7
--- /dev/null
+++ b/dom/quota/test/marionette/quota_test_case.py
@@ -0,0 +1,113 @@
+# 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/.
+
+import os
+from contextlib import contextmanager
+
+from marionette_driver import Wait
+from marionette_harness import MarionetteTestCase
+
+
+class QuotaTestCase(MarionetteTestCase):
+ def ensureInvariantHolds(self, op):
+ maxWaitTime = 60
+ Wait(self.marionette, timeout=maxWaitTime).until(
+ op,
+ message=f"operation did not yield success even after waiting {maxWaitTime}s time",
+ )
+
+ def findDirObj(self, path, pattern, isFile):
+ for obj in os.scandir(path):
+ if obj.path.endswith(pattern) and (obj.is_file() == isFile):
+ return obj.path
+ return None
+
+ def getFullOriginMetadata(self, persistenceType, origin):
+ with self.marionette.using_context("chrome"):
+ res = self.marionette.execute_async_script(
+ """
+ const [persistenceType, origin, resolve] = arguments;
+
+ const principal = Services.scriptSecurityManager.
+ createContentPrincipalFromOrigin(origin);
+
+ const request = Services.qms.getFullOriginMetadata(
+ persistenceType, principal);
+
+ request.callback = function() {
+ if (request.resultCode != Cr.NS_OK) {
+ resolve(null);
+ } else {
+ resolve(request.result);
+ }
+ }
+ """,
+ script_args=(persistenceType, origin),
+ new_sandbox=False,
+ )
+
+ assert res is not None
+ return res
+
+ def getStoragePath(self, profilePath, origin, persistenceType, client):
+ fullOriginMetadata = self.getFullOriginMetadata(persistenceType, origin)
+
+ storageOrigin = fullOriginMetadata["storageOrigin"]
+ sanitizedStorageOrigin = storageOrigin.replace(":", "+").replace("/", "+")
+
+ return os.path.join(
+ profilePath, "storage", persistenceType, sanitizedStorageOrigin, client
+ )
+
+ def resetStoragesForPrincipal(self, origin, persistenceType, client):
+ # This method is used to force sqlite to write journal file contents to
+ # main sqlite database file
+
+ script = """
+ const [resolve] = arguments
+
+ let origin = '%s';
+ let persistenceType = '%s';
+ let client = '%s';
+ let principal = Services.scriptSecurityManager.
+ createContentPrincipalFromOrigin(origin);
+
+ let req = Services.qms.resetStoragesForPrincipal(principal, persistenceType, client);
+ req.callback = () => {
+ if (req.resultCode == Cr.NS_OK) {
+ resolve(true);
+ } else {
+ resolve(false);
+ }
+ }
+ """ % (
+ origin,
+ persistenceType,
+ client,
+ )
+
+ with self.marionette.using_context(self.marionette.CONTEXT_CHROME):
+ return self.marionette.execute_async_script(script)
+
+ @contextmanager
+ def using_new_window(self, path, private=False):
+ """
+ This helper method is created to ensure that a temporary
+ window required inside the test scope is lifetime'd properly
+ """
+
+ oldWindow = self.marionette.current_window_handle
+ try:
+ newWindow = self.marionette.open(type="window", private=private)
+ self.marionette.switch_to_window(newWindow["handle"])
+ self.marionette.navigate(self.marionette.absolute_url(path))
+ origin = self.marionette.absolute_url("")[:-1]
+ if private:
+ origin += "^privateBrowsingId=1"
+
+ yield (origin, "private" if private else "default")
+
+ finally:
+ self.marionette.close()
+ self.marionette.switch_to_window(oldWindow)