Skip to content

Commit

Permalink
Bug 1733156 [wpt PR 30835] - dwpas: Add tentative WPT test for protoc…
Browse files Browse the repository at this point in the history
…ol_handler, a=testonly

Automatic update from web-platform-tests
dwpas: Add tentative WPT test for protocol_handler

Adding manual WPT test for new protocol_handler field.
w3c/manifest#846

Bug: 1019239
Change-Id: I49bbcae9ff1925fb2799d1462fca936147f2e118
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3166820
Reviewed-by: Evan Stade <[email protected]>
Reviewed-by: Joshua Bell <[email protected]>
Commit-Queue: Mike Jackson <[email protected]>
Cr-Commit-Position: refs/heads/main@{#924924}

--

wpt-commits: e88c2d6ca49cb21f547ff84201659d1a39d1c4ae
wpt-pr: 30835
  • Loading branch information
mwjacksonmsft authored and moz-wptsync-bot committed Oct 4, 2021
1 parent 2043dee commit f9e74ab
Show file tree
Hide file tree
Showing 6 changed files with 124 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<link rel="manifest" href="resources/protocol_handlers-member.webmanifest" />
<title>Protocol Handling Web Platform Test</title>
<script>
navigator.serviceWorker.register(
'protocol_handlers-member-service-worker.js');
</script>
</head>
<body>
<h1>Protocol Handling Web Platform Test</h1>
<p>This test validates that an install application can register URL protocol
handlers via a property in the web app manifest. The app should open
directly when the 'web+testing' custom-scheme URL is visited.
</p>
<h2>Manual Test Steps:</h2>
<p>
<ol>
<li>Install this app.</li>
<li>Launch 'web+testing://test-url/'. Instructions will vary by OS.
<ul>
<li>On Windows - open a command prompt, and run "start web+testing://test-url/".</li>
<li>On MacOS - open a terminal, and "open web+testing://test-url/".</li>
<li>On Linux - open a terminal, and "xgd-open web+testing://test-url/".</li>
</ul>
</li>
<li>If your browser prompts you, allow the app to open.</li>
<li>The app window that opens should indicate success of this test.</li>
</ol>
</p>
</body>
</html>
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
// Some user agents only offer app installation if there is a SW and it handles
// offline requests.

const cacheVersion = "1.1";
const CACHE_NAME = `cache-v${cacheVersion}`;

// The resources cached by this service worker.
const resources = [
"protocol_handlers-member-service-worker.js",
"protocol_handlers-member-manual.tentative.html",
"resources/icon.png",
"resources/protocol_handlers_entry.html",
];

// Load all resources for this service worker.
const precache = async () => {
const cache = await caches.open(CACHE_NAME);
await cache.addAll(resources);
};

// Get a resource from the cache.
const fromCache = async request => {
const cache = await caches.open(CACHE_NAME);
return await cache.match(request.url);
};

// Attempt to get resources from the network first, fallback to the cache if we're
// offline.
const networkFallbackToCache = async request => {
try {
const response = await fetch(request);
if (response.ok) return response;
} catch (err) {}
return await fromCache(request);
};

// When we have a new service worker, update the caches and swap immediately.
self.addEventListener("install", e => {
e.waitUntil(precache().then(() => self.skipWaiting()));
});

// Claim existing clients.
self.addEventListener("activate", e => {
e.waitUntil(self.clients.claim());
});

// When a resource need to be fetched, check whether it is
// contained in the cache and return the cached version, otherwise
// get it from the network.
self.addEventListener("fetch", e => {
e.respondWith(networkFallbackToCache(e.request));
});
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"name": "Protocol_handlers test",
"icons": [
{
"src": "icon.png",
"sizes": "144x144"
}
],
"start_url": "../protocol_handlers-member-manual.tentative.html",
"display": "standalone",
"scope": "../../protocol_handlers-member/",
"protocol_handlers": [
{
"protocol": "web+testing",
"url": "protocol_handlers_entry.html?value=%s"
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Content-Type: application/manifest+json; charset=utf-8
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Protocol Handling Web Platform Test - Pass</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script>
setup({ single_test: true });
const urlParams = new URLSearchParams(window.location.search);
assert_equals(urlParams.get('value'), "web+testing://test-url/");
done();
</script>
</head>
<body>
<h1>Protocol Handling Page</h1>
<p>This test validates that the app was launched with the web+testing://test-url/ URL.</p>
</body>
</html>

0 comments on commit f9e74ab

Please sign in to comment.