summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/resource-timing/entries-for-network-errors.sub.https.html
blob: ebc2247babcd4ab94d1fdd826d17d8c968189d79 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8" />
<title>This test validates that a failed cross-origin fetch creates an opaque network timing entry.
</title>
<link rel="author" title="Noam Rosenthal" href="noam@webkit.org">
<link rel="help" href="https://www.w3.org/TR/resource-timing-2/#sec-performanceresourcetiming"/>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script src="resources/entry-invariants.js"></script>
</head>
<body>
<script>
const validDataURL = 'data:,Hello%2C%20World%21'
const {REMOTE_ORIGIN, ORIGINAL_HOST, HTTP_PORT} = get_host_info();
const validXmlUrl = '/common/dummy.xml';

network_error_entry_test(
    `${REMOTE_ORIGIN}${validXmlUrl}`, null, `failed cross-origin requests`);

network_error_entry_test(`/common/redirect.py?location=${validDataURL}`, null, "non-HTTP redirect");
network_error_entry_test('//{{hosts[][nonexistent]}}/common/dummy.xml', null, "DNS failure");
network_error_entry_test(`http://${ORIGINAL_HOST}:${HTTP_PORT}/commo/dummy.xml`, null, "Mixed content");

network_error_entry_test('/common/dummy.xml', {cache: 'only-if-cached', mode: 'same-origin'},
    "only-if-cached resource that was not cached");

network_error_entry_test(
    `/element-timing/resources/multiple-redirects.py?redirect_count=22&final_resource=${validXmlUrl}`,
    null, "too many redirects");

// ORB (https://github.com/whatwg/fetch/pull/1442) will return network errors
// for certain cross-origin fetches. This tests that the same rules apply to
// these fetches. Since ORB (at least as presently implemented) doesn't return
// network errors for fetches, we have to load this case using an <img> element.
//
// This emulates a case previously tested in service-workers/service-worker/resource-timing.sub.https.html
const orb_loader = (url, _) => new Promise(resolve => {
  const img = document.createElement("img");
  img.src = url;
  img.onerror = resolve;
  document.body.appendChild(img);
} );
network_error_entry_test(
    '//{{hosts[alt][]}}:{{ports[https][0]}}/service-workers/service-worker/resources/missing.jpg',
    null, "network error for ORB-blocked response", orb_loader);
</script>
</body>
</html>