summaryrefslogtreecommitdiffstats
path: root/devtools/client/styleeditor/test/iframe_with_service_worker.html
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/styleeditor/test/iframe_with_service_worker.html')
-rw-r--r--devtools/client/styleeditor/test/iframe_with_service_worker.html33
1 files changed, 33 insertions, 0 deletions
diff --git a/devtools/client/styleeditor/test/iframe_with_service_worker.html b/devtools/client/styleeditor/test/iframe_with_service_worker.html
new file mode 100644
index 0000000000..690515775e
--- /dev/null
+++ b/devtools/client/styleeditor/test/iframe_with_service_worker.html
@@ -0,0 +1,33 @@
+<!DOCTYPE html>
+<meta charset="utf-8">
+
+Iframe loading a stylesheet via a service worker
+<script>
+"use strict";
+
+function waitForActive(swr) {
+ const sw = swr.installing || swr.waiting || swr.active;
+ return new Promise(resolve => {
+ if (sw.state === "activated") {
+ resolve(swr);
+ return;
+ }
+ sw.addEventListener("statechange", function onStateChange(evt) {
+ if (sw.state === "activated") {
+ sw.removeEventListener("statechange", onStateChange);
+ resolve(swr);
+ }
+ });
+ });
+}
+
+navigator.serviceWorker.register("iframe_service_worker.js", {scope: "."})
+ .then(registration => waitForActive(registration))
+ .then(() => {
+ const link = document.createElement("link");
+ link.setAttribute("rel", "stylesheet");
+ link.setAttribute("type", "text/css");
+ link.setAttribute("href", "sheet.css");
+ document.documentElement.appendChild(link);
+ });
+</script>