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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
const HTML_DATA = `
<!DOCTYPE HTML>
<html>
<head>
<title>Dummy test page</title>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"></meta>
</head>
<body>
<p>Dummy test page</p>
<div id="testDiv">test</div>
<img src="data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUA
AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" />
</body>
</html>
`;
const WORKER = `
self.onmessage = function(e) {
if (e.data.type == "runCmdAndGetResult") {
let result = eval(e.data.cmd);
postMessage({ type: "result", resultOf: e.data.cmd, result: result });
return;
} else if (e.data.type == "runCmds") {
for (let cmd of e.data.cmds) {
eval(cmd);
}
postMessage({ type: "result", resultOf: "entriesLength", result: performance.getEntries().length });
return;
} else if (e.data.type == "getResult") {
if (e.data.resultOf == "startTimeAndDuration") {
postMessage({ type: "result",
resultOf: "startTimeAndDuration",
result: {
index: e.data.num,
startTime: performance.getEntries()[e.data.num].startTime,
duration: performance.getEntries()[e.data.num].duration,
}
});
return;
} else if (e.data.resultOf == "getEntriesByTypeLength") {
postMessage({
type: "result",
resultOf: "entriesByTypeLength",
result: {
markLength: performance.getEntriesByType("mark").length,
resourceLength: performance.getEntriesByType("resource").length,
testAndMarkLength: performance.getEntriesByName("Test", "mark").length,
}
});
return;
}
}
postMessage({ type: "unexpectedMessageType", data: e.data.type });
};
`;
function handleRequest(request, response) {
let query = new URLSearchParams(request.queryString);
if (query.get("crossOriginIsolated") === "true") {
response.setHeader("Cross-Origin-Opener-Policy", "same-origin", false);
response.setHeader("Cross-Origin-Embedder-Policy", "require-corp", false);
}
if (query.get("worker")) {
response.setHeader("Cache-Control", "no-cache", false);
response.setHeader("Content-Type", "application/javascript");
response.write(WORKER);
return;
}
response.setHeader("Cache-Control", "no-cache", false);
response.setHeader("Content-Type", "text/html", false);
response.write(HTML_DATA);
}
|