@checkly/playwright-core 1.48.20 → 1.48.22-beta
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/checkly/fetch.js +3 -10
- package/lib/cli/cli.js +61 -0
- package/lib/common/debugLogger.js +90 -0
- package/lib/generated/recorderSource.js +1 -1
- package/lib/server/fetch.js +1 -1
- package/lib/server/recorder/java.js +4 -36
- package/lib/server/trace/recorder/tracing.js +22 -17
- package/lib/vite/{traceViewer/assets/codeMirrorModule-B7Z3vq11.js → recorder/assets/codeMirrorModule-CR6kB851.js} +1 -1
- package/lib/vite/recorder/assets/{index-Bxxcmxlu.js → index-BcaUAUCW.js} +2 -2
- package/lib/vite/recorder/index.html +1 -1
- package/lib/vite/traceViewer/assets/codeMirrorModule-75b0ca4f.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-CNHvVrFd.js +16437 -0
- package/lib/vite/traceViewer/assets/{codeMirrorModule-BdBhzV6t.js → codeMirrorModule-CpGx_S8D.js} +2 -2
- package/lib/vite/traceViewer/assets/{codeMirrorModule-EhKN7Okm.js → codeMirrorModule-DGE2kpkE.js} +954 -960
- package/lib/vite/traceViewer/assets/codeMirrorModule-SomGa-Da.js +16443 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-c1454a2e.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-c9bb9834.js +24 -0
- package/lib/vite/traceViewer/assets/{codeMirrorModule-BqcXH1AO.js → codeMirrorModule-cc2329e4.js} +11 -1256
- package/lib/vite/traceViewer/assets/codeMirrorModule-d2cc7db0.js +15579 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-da915a35.js +15586 -0
- package/lib/vite/traceViewer/assets/{codeMirrorModule-U6XMqGkV.js → codeMirrorModule-f03b1a3e.js} +661 -1519
- package/lib/vite/traceViewer/assets/codeMirrorModule-f333a775.js +24 -0
- package/lib/vite/traceViewer/assets/{codeMirrorModule-V7N6ppkd.js → codeMirrorModule-uWDlVSQz.js} +2 -2
- package/lib/vite/traceViewer/assets/{codeMirrorModule-Dx6AXgMV.js → codeMirrorModule-yboVpgC0.js} +2 -1248
- package/lib/vite/traceViewer/assets/{inspectorTab-BABZNwlH.js → inspectorTab-B4ynvyY9.js} +18 -8
- package/lib/vite/traceViewer/assets/{inspectorTab-DpvLVMq5.js → inspectorTab-CHcHvp_a.js} +16 -6
- package/lib/vite/traceViewer/assets/{workbench-Bjkiwcr1.js → inspectorTab-Dw0Gnh1T.js} +1847 -3605
- package/lib/vite/traceViewer/assets/{inspectorTab-BPzVEZSf.js → inspectorTab-Ywa000c9.js} +16 -6
- package/lib/vite/traceViewer/assets/{workbench-BcgGQnKb.js → workbench-CROk6Fcc.js} +2 -2
- package/lib/vite/traceViewer/assets/{workbench-ByyWxoT8.js → workbench-CfXOj3eT.js} +2 -2
- package/lib/vite/traceViewer/assets/{workbench-DhqI6jeL.js → workbench-D9CTkv-4.js} +2 -2
- package/lib/vite/traceViewer/assets/{workbench-I4s6sWjN.js → workbench-DNolpp3y.js} +1 -1
- package/lib/vite/traceViewer/assets/workbench-DjoIOtwK.js +1473 -0
- package/lib/vite/traceViewer/assets/workbench-dnZM5a7x.js +1473 -0
- package/lib/vite/traceViewer/assets/wsPort-54626118.js +18361 -0
- package/lib/vite/traceViewer/assets/wsPort-57f274c6.js +18361 -0
- package/lib/vite/traceViewer/assets/wsPort-762c6840.js +64 -0
- package/lib/vite/traceViewer/assets/wsPort-85286e61.js +18361 -0
- package/lib/vite/traceViewer/assets/wsPort-98e00a94.js +64 -0
- package/lib/vite/traceViewer/assets/{wsPort-EUvw-dwH.js → wsPort-CAXygIGt.js} +3 -3
- package/lib/vite/traceViewer/assets/{workbench-Crj6jzdv.js → wsPort-cc0077b5.js} +4046 -4623
- package/lib/vite/traceViewer/assets/wsPort-edfeeb7d.js +64 -0
- package/lib/vite/traceViewer/assets/wsPort-ee2830d7.js +64 -0
- package/lib/vite/traceViewer/assets/{workbench-C5OQh9VX.js → wsPort-peeLnQhT.js} +985 -1540
- package/lib/vite/traceViewer/assets/xtermModule-443332e6.js +9 -0
- package/lib/vite/traceViewer/assets/xtermModule-60687b6b.js +6410 -0
- package/lib/vite/traceViewer/codeMirrorModule.5d0f417c.css +1 -0
- package/lib/vite/traceViewer/codeMirrorModule.eb494ea9.css +344 -0
- package/lib/vite/traceViewer/codicon.79f233d0.ttf +0 -0
- package/lib/vite/traceViewer/{embedded.27BGR_eD.js → embedded.6N1v7bZ1.js} +4 -3
- package/lib/vite/traceViewer/{embedded.DTjd2aiy.js → embedded.BaqdbLsy.js} +4 -3
- package/lib/vite/traceViewer/{embedded.SsjKHrxC.js → embedded.CwwTDBzP.js} +4 -3
- package/lib/vite/traceViewer/{embedded.Zu332ZC1.js → embedded.DeCrOtlO.js} +2 -2
- package/lib/vite/traceViewer/embedded.DnD_eIZU.js +106 -0
- package/lib/vite/traceViewer/embedded.html +3 -3
- package/lib/vite/traceViewer/embedded.i_k4ceMJ.js +106 -0
- package/lib/vite/traceViewer/index.1a1fe659.css +1 -0
- package/lib/vite/traceViewer/index.1b525c1c.js +181 -0
- package/lib/vite/traceViewer/index.55e65778.js +181 -0
- package/lib/vite/traceViewer/{index.6KJ-JQ0L.js → index.5nqVcfiC.js} +2 -2
- package/lib/vite/traceViewer/{index.C0EgJ4oW.js → index.5ooko4n7.js} +21 -36
- package/lib/vite/traceViewer/index.76e9f312.css +124 -0
- package/lib/vite/traceViewer/{index.Dz3icWJV.js → index.Bugo2TbS.js} +4 -3
- package/lib/vite/traceViewer/{index.PqcsvBxQ.js → index.BzvnAP7t.js} +4 -3
- package/lib/vite/traceViewer/{index.CLxsp2W_.js → index.CM_h9lHr.js} +2 -2
- package/lib/vite/traceViewer/{index.yxAwzeWG.js → index.CY13pBr8.js} +4 -3
- package/lib/vite/traceViewer/index.DblJtEW_.js +197 -0
- package/lib/vite/traceViewer/index.UtHmfPiA.js +197 -0
- package/lib/vite/traceViewer/index.a265fbdb.js +2 -0
- package/lib/vite/traceViewer/index.c9f6fa8f.js +2 -0
- package/lib/vite/traceViewer/index.d86e70ca.js +181 -0
- package/lib/vite/traceViewer/index.decad628.js +2 -0
- package/lib/vite/traceViewer/index.e8730524.js +181 -0
- package/lib/vite/traceViewer/index.ed9a3c58.js +2 -0
- package/lib/vite/traceViewer/index.html +3 -3
- package/lib/vite/traceViewer/{recorder.BufKu9Hp.js → recorder.3Xfrl_zV.js} +3 -2
- package/lib/vite/traceViewer/{recorder.am-MV-DQ.js → recorder.BWH6blRw.js} +3 -2
- package/lib/vite/traceViewer/{recorder.7Wl6HrQl.js → recorder.Db1aK_DY.js} +3 -2
- package/lib/vite/traceViewer/recorder.html +2 -2
- package/lib/vite/traceViewer/recorder.uj3cfoMf.js +551 -0
- package/lib/vite/traceViewer/uiMode.08ab2d90.js +4 -0
- package/lib/vite/traceViewer/uiMode.0d0d667b.js +4 -0
- package/lib/vite/traceViewer/uiMode.216233d5.js +1484 -0
- package/lib/vite/traceViewer/{uiMode.DVWUEIHq.css → uiMode.2c31018f.css} +88 -188
- package/lib/vite/traceViewer/uiMode.3ff70f7d.js +4 -0
- package/lib/vite/traceViewer/uiMode.4d0a45af.js +1484 -0
- package/lib/vite/traceViewer/uiMode.66eb0ce2.js +1484 -0
- package/lib/vite/traceViewer/uiMode.8b41a49d.css +1 -0
- package/lib/vite/traceViewer/uiMode.8d080c01.js +1486 -0
- package/lib/vite/traceViewer/uiMode.BKrDfnAk.js +1725 -0
- package/lib/vite/traceViewer/uiMode.BMYUvsRh.js +1725 -0
- package/lib/vite/traceViewer/{uiMode.BZoFj6zV.js → uiMode.BVpTBGoe.js} +4 -3
- package/lib/vite/traceViewer/uiMode.BWhJCEE9.js +1725 -0
- package/lib/vite/traceViewer/uiMode.Bg9fACTB.js +1725 -0
- package/lib/vite/traceViewer/{uiMode.CpC2B27N.js → uiMode.CYBsUhm_.js} +2 -2
- package/lib/vite/traceViewer/{uiMode.Dlo9s_YX.js → uiMode.DCSdxlAq.js} +4 -3
- package/lib/vite/traceViewer/{uiMode.wsGnVMQK.js → uiMode.DtleKuGI.js} +4 -3
- package/lib/vite/traceViewer/uiMode.UamAvOMX.js +1725 -0
- package/lib/vite/traceViewer/uiMode._Kp3dUXk.js +1724 -0
- package/lib/vite/traceViewer/uiMode.bBcXYWNF.js +1725 -0
- package/lib/vite/traceViewer/uiMode.ca6ec898.js +4 -0
- package/lib/vite/traceViewer/{uiMode.iq7CyYy7.js → uiMode.e-PLonGl.js} +2 -2
- package/lib/vite/traceViewer/uiMode.e_-GuqEi.js +1725 -0
- package/lib/vite/traceViewer/uiMode.f1YADWIl.js +1724 -0
- package/lib/vite/traceViewer/uiMode.html +3 -3
- package/lib/vite/traceViewer/uiMode.kHsXCfV8.js +1490 -0
- package/lib/vite/traceViewer/{workbench.B3X2QtYa.css → wsPort.162042f9.css} +63 -315
- package/lib/vite/traceViewer/{workbench.wuxQoE2z.css → wsPort.997c92cf.css} +145 -335
- package/lib/vite/traceViewer/wsPort.9c9a6767.css +1 -0
- package/lib/vite/traceViewer/xtermModule.125f4259.css +191 -0
- package/lib/vite/traceViewer/xtermModule.6428296b.css +32 -0
- package/package.json +1 -1
- package/lib/vite/recorder/assets/codeMirrorModule-d0KhC1qL.js +0 -24
- package/lib/vite/traceViewer/assets/codeMirrorModule-5yiV-3wl.js +0 -16831
- package/lib/vite/traceViewer/assets/codeMirrorModule-C6p3E9Zg.js +0 -24
- package/lib/vite/traceViewer/assets/codeMirrorModule-Ca-1BNel.js +0 -24
- package/lib/vite/traceViewer/assets/codeMirrorModule-CcviAl53.js +0 -16831
- package/lib/vite/traceViewer/assets/codeMirrorModule-CqYUz5ms.js +0 -24
- package/lib/vite/traceViewer/assets/codeMirrorModule-DS3v0XrQ.js +0 -24
- package/lib/vite/traceViewer/assets/codeMirrorModule-DZoSgqUd.js +0 -24
- package/lib/vite/traceViewer/assets/codeMirrorModule-MzSmL4X2.js +0 -24
- package/lib/vite/traceViewer/assets/codeMirrorModule-T_sdMrbM.js +0 -24
- package/lib/vite/traceViewer/assets/inspectorTab-BHcfR9dD.js +0 -64
- package/lib/vite/traceViewer/assets/inspectorTab-Bbgq0hgt.js +0 -64
- package/lib/vite/traceViewer/assets/inspectorTab-DhBbZz8I.js +0 -64
- package/lib/vite/traceViewer/assets/workbench-B13nfocr.js +0 -9
- package/lib/vite/traceViewer/assets/workbench-BwodYCgl.js +0 -19119
- package/lib/vite/traceViewer/assets/workbench-C43LWZEX.js +0 -72
- package/lib/vite/traceViewer/assets/workbench-DZqNXdoV.js +0 -9
- package/lib/vite/traceViewer/assets/workbench-DrQjKdyE.js +0 -72
- package/lib/vite/traceViewer/assets/workbench-Pa1v1Ojh.js +0 -72
- package/lib/vite/traceViewer/assets/workbench-caTaZnzx.js +0 -72
- package/lib/vite/traceViewer/assets/workbench-gtYcQBNA.js +0 -9
- package/lib/vite/traceViewer/assets/workbench-u2lRPMOT.js +0 -72
- package/lib/vite/traceViewer/assets/xtermModule-CZ7sDYXB.js +0 -6529
- package/lib/vite/traceViewer/embedded.BBZ9gQEw.js +0 -104
- package/lib/vite/traceViewer/embedded.BQq6Psnz.js +0 -104
- package/lib/vite/traceViewer/embedded.BVDVQOzc.js +0 -2
- package/lib/vite/traceViewer/embedded.Bn8Ptzv6.js +0 -2
- package/lib/vite/traceViewer/embedded.CorI3dFX.js +0 -104
- package/lib/vite/traceViewer/embedded.CvhnUgIi.js +0 -2
- package/lib/vite/traceViewer/embedded.D27cnKiB.js +0 -104
- package/lib/vite/traceViewer/embedded.D4lqGydT.js +0 -2
- package/lib/vite/traceViewer/embedded.DPqrDeET.js +0 -2
- package/lib/vite/traceViewer/embedded.DbzY7Q8w.js +0 -2
- package/lib/vite/traceViewer/embedded.Dxe2heQk.js +0 -2
- package/lib/vite/traceViewer/embedded.f-PLGsBT.js +0 -2
- package/lib/vite/traceViewer/index.B7aiTMfZ.js +0 -2
- package/lib/vite/traceViewer/index.B8dgQwuN.js +0 -2
- package/lib/vite/traceViewer/index.BGj8jY3H.js +0 -2
- package/lib/vite/traceViewer/index.BSak5QT9.js +0 -2
- package/lib/vite/traceViewer/index.BrT2kfuc.js +0 -2
- package/lib/vite/traceViewer/index.CB297BuW.js +0 -2
- package/lib/vite/traceViewer/index.CUpI-BFe.js +0 -195
- package/lib/vite/traceViewer/index.DkRbtWVo.js +0 -195
- package/lib/vite/traceViewer/index.DsjmhbB6.js +0 -195
- package/lib/vite/traceViewer/index._cX8k4co.js +0 -2
- package/lib/vite/traceViewer/index.pMAN88y-.js +0 -2
- package/lib/vite/traceViewer/recorder.C88JDknq.js +0 -2
- package/lib/vite/traceViewer/recorder.Ch-WHviK.js +0 -2
- package/lib/vite/traceViewer/recorder.POd-toIn.js +0 -2
- package/lib/vite/traceViewer/uiMode.2tr9k625.js +0 -5
- package/lib/vite/traceViewer/uiMode.BEZVCe5O.js +0 -5
- package/lib/vite/traceViewer/uiMode.C4nbcio6.js +0 -1730
- package/lib/vite/traceViewer/uiMode.D-tg1Oci.js +0 -1730
- package/lib/vite/traceViewer/uiMode.D3cNFP6u.css +0 -1
- package/lib/vite/traceViewer/uiMode.DKjMBMlc.js +0 -1730
- package/lib/vite/traceViewer/uiMode.DVrL7a1K.js +0 -10
- package/lib/vite/traceViewer/uiMode.DdtUZZVS.js +0 -5
- package/lib/vite/traceViewer/uiMode.Dg9oJCQU.js +0 -10
- package/lib/vite/traceViewer/uiMode.DwZAzstF.js +0 -10
- package/lib/vite/traceViewer/uiMode.O07awP3T.js +0 -10
- package/lib/vite/traceViewer/uiMode.gGHHTsyL.js +0 -1730
- package/lib/vite/traceViewer/uiMode.jY2s-9ps.js +0 -10
- package/lib/vite/traceViewer/workbench.DjbIuxix.css +0 -1
- package/lib/vite/traceViewer/workbench.DyTpxWVb.css +0 -1
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import { M as MultiTraceModel, r as reactExports, c as connect, j as jsxs, a as jsx, T as ToolbarButton, t as toggleTheme, W as Workbench, b as applyTheme, d as reactDomExports } from "./assets/wsPort-57f274c6.js";
|
|
2
|
+
const workbenchLoader = "";
|
|
3
|
+
const WorkbenchLoader = () => {
|
|
4
|
+
const [isServer, setIsServer] = reactExports.useState(false);
|
|
5
|
+
const [traceURLs, setTraceURLs] = reactExports.useState([]);
|
|
6
|
+
const [uploadedTraceNames, setUploadedTraceNames] = reactExports.useState([]);
|
|
7
|
+
const [model, setModel] = reactExports.useState(emptyModel);
|
|
8
|
+
const [progress, setProgress] = reactExports.useState({ done: 0, total: 0 });
|
|
9
|
+
const [dragOver, setDragOver] = reactExports.useState(false);
|
|
10
|
+
const [processingErrorMessage, setProcessingErrorMessage] = reactExports.useState(null);
|
|
11
|
+
const [fileForLocalModeError, setFileForLocalModeError] = reactExports.useState(null);
|
|
12
|
+
const processTraceFiles = reactExports.useCallback((files) => {
|
|
13
|
+
const blobUrls = [];
|
|
14
|
+
const fileNames = [];
|
|
15
|
+
const url = new URL(window.location.href);
|
|
16
|
+
for (let i = 0; i < files.length; i++) {
|
|
17
|
+
const file = files.item(i);
|
|
18
|
+
if (!file)
|
|
19
|
+
continue;
|
|
20
|
+
const blobTraceURL = URL.createObjectURL(file);
|
|
21
|
+
blobUrls.push(blobTraceURL);
|
|
22
|
+
fileNames.push(file.name);
|
|
23
|
+
url.searchParams.append("trace", blobTraceURL);
|
|
24
|
+
url.searchParams.append("traceFileName", file.name);
|
|
25
|
+
}
|
|
26
|
+
const href = url.toString();
|
|
27
|
+
window.history.pushState({}, "", href);
|
|
28
|
+
setTraceURLs(blobUrls);
|
|
29
|
+
setUploadedTraceNames(fileNames);
|
|
30
|
+
setDragOver(false);
|
|
31
|
+
setProcessingErrorMessage(null);
|
|
32
|
+
}, []);
|
|
33
|
+
const handleDropEvent = reactExports.useCallback((event) => {
|
|
34
|
+
event.preventDefault();
|
|
35
|
+
processTraceFiles(event.dataTransfer.files);
|
|
36
|
+
}, [processTraceFiles]);
|
|
37
|
+
const handleFileInputChange = reactExports.useCallback((event) => {
|
|
38
|
+
event.preventDefault();
|
|
39
|
+
if (!event.target.files)
|
|
40
|
+
return;
|
|
41
|
+
processTraceFiles(event.target.files);
|
|
42
|
+
}, [processTraceFiles]);
|
|
43
|
+
reactExports.useEffect(() => {
|
|
44
|
+
const params = new URL(window.location.href).searchParams;
|
|
45
|
+
const newTraceURLs = params.getAll("trace");
|
|
46
|
+
setIsServer(params.has("isServer"));
|
|
47
|
+
for (const url of newTraceURLs) {
|
|
48
|
+
if (url.startsWith("file:")) {
|
|
49
|
+
setFileForLocalModeError(url || null);
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
if (params.has("isServer")) {
|
|
54
|
+
connect({
|
|
55
|
+
onEvent(method, params2) {
|
|
56
|
+
if (method === "loadTrace") {
|
|
57
|
+
setTraceURLs(params2.url ? [params2.url] : []);
|
|
58
|
+
setDragOver(false);
|
|
59
|
+
setProcessingErrorMessage(null);
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
onClose() {
|
|
63
|
+
}
|
|
64
|
+
}).then((sendMessage) => {
|
|
65
|
+
sendMessage("ready");
|
|
66
|
+
});
|
|
67
|
+
} else if (!newTraceURLs.some((url) => url.startsWith("blob:"))) {
|
|
68
|
+
setTraceURLs(newTraceURLs);
|
|
69
|
+
}
|
|
70
|
+
}, []);
|
|
71
|
+
reactExports.useEffect(() => {
|
|
72
|
+
(async () => {
|
|
73
|
+
if (traceURLs.length) {
|
|
74
|
+
const swListener = (event) => {
|
|
75
|
+
if (event.data.method === "progress")
|
|
76
|
+
setProgress(event.data.params);
|
|
77
|
+
};
|
|
78
|
+
navigator.serviceWorker.addEventListener("message", swListener);
|
|
79
|
+
setProgress({ done: 0, total: 1 });
|
|
80
|
+
const contextEntries = [];
|
|
81
|
+
for (let i = 0; i < traceURLs.length; i++) {
|
|
82
|
+
const url = traceURLs[i];
|
|
83
|
+
const params = new URLSearchParams();
|
|
84
|
+
params.set("trace", url);
|
|
85
|
+
if (uploadedTraceNames.length)
|
|
86
|
+
params.set("traceFileName", uploadedTraceNames[i]);
|
|
87
|
+
const response = await fetch(`contexts?${params.toString()}`);
|
|
88
|
+
if (!response.ok) {
|
|
89
|
+
if (!isServer)
|
|
90
|
+
setTraceURLs([]);
|
|
91
|
+
setProcessingErrorMessage((await response.json()).error);
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
contextEntries.push(...await response.json());
|
|
95
|
+
}
|
|
96
|
+
navigator.serviceWorker.removeEventListener("message", swListener);
|
|
97
|
+
const model2 = new MultiTraceModel(contextEntries);
|
|
98
|
+
setProgress({ done: 0, total: 0 });
|
|
99
|
+
setModel(model2);
|
|
100
|
+
} else {
|
|
101
|
+
setModel(emptyModel);
|
|
102
|
+
}
|
|
103
|
+
})();
|
|
104
|
+
}, [isServer, traceURLs, uploadedTraceNames]);
|
|
105
|
+
return /* @__PURE__ */ jsxs("div", { className: "vbox workbench-loader", onDragOver: (event) => {
|
|
106
|
+
event.preventDefault();
|
|
107
|
+
setDragOver(true);
|
|
108
|
+
}, children: [
|
|
109
|
+
/* @__PURE__ */ jsxs("div", { className: "hbox header", children: [
|
|
110
|
+
/* @__PURE__ */ jsx("div", { className: "logo", children: /* @__PURE__ */ jsx("img", { src: "playwright-logo.svg", alt: "Playwright logo" }) }),
|
|
111
|
+
/* @__PURE__ */ jsx("div", { className: "product", children: "Playwright" }),
|
|
112
|
+
model.title && /* @__PURE__ */ jsx("div", { className: "title", children: model.title }),
|
|
113
|
+
/* @__PURE__ */ jsx("div", { className: "spacer" }),
|
|
114
|
+
/* @__PURE__ */ jsx(ToolbarButton, { icon: "color-mode", title: "Toggle color mode", toggled: false, onClick: () => toggleTheme() })
|
|
115
|
+
] }),
|
|
116
|
+
/* @__PURE__ */ jsx("div", { className: "progress", children: /* @__PURE__ */ jsx("div", { className: "inner-progress", style: { width: progress.total ? 100 * progress.done / progress.total + "%" : 0 } }) }),
|
|
117
|
+
/* @__PURE__ */ jsx(Workbench, { model }),
|
|
118
|
+
fileForLocalModeError && /* @__PURE__ */ jsxs("div", { className: "drop-target", children: [
|
|
119
|
+
/* @__PURE__ */ jsx("div", { children: "Trace Viewer uses Service Workers to show traces. To view trace:" }),
|
|
120
|
+
/* @__PURE__ */ jsxs("div", { style: { paddingTop: 20 }, children: [
|
|
121
|
+
/* @__PURE__ */ jsxs("div", { children: [
|
|
122
|
+
"1. Click ",
|
|
123
|
+
/* @__PURE__ */ jsx("a", { href: fileForLocalModeError, children: "here" }),
|
|
124
|
+
" to put your trace into the download shelf"
|
|
125
|
+
] }),
|
|
126
|
+
/* @__PURE__ */ jsxs("div", { children: [
|
|
127
|
+
"2. Go to ",
|
|
128
|
+
/* @__PURE__ */ jsx("a", { href: "https://trace.playwright.dev", children: "trace.playwright.dev" })
|
|
129
|
+
] }),
|
|
130
|
+
/* @__PURE__ */ jsx("div", { children: "3. Drop the trace from the download shelf into the page" })
|
|
131
|
+
] })
|
|
132
|
+
] }),
|
|
133
|
+
!isServer && !dragOver && !fileForLocalModeError && (!traceURLs.length || processingErrorMessage) && /* @__PURE__ */ jsxs("div", { className: "drop-target", children: [
|
|
134
|
+
/* @__PURE__ */ jsx("div", { className: "processing-error", children: processingErrorMessage }),
|
|
135
|
+
/* @__PURE__ */ jsx("div", { className: "title", children: "Drop Playwright Trace to load" }),
|
|
136
|
+
/* @__PURE__ */ jsx("div", { children: "or" }),
|
|
137
|
+
/* @__PURE__ */ jsx("button", { onClick: () => {
|
|
138
|
+
const input = document.createElement("input");
|
|
139
|
+
input.type = "file";
|
|
140
|
+
input.multiple = true;
|
|
141
|
+
input.click();
|
|
142
|
+
input.addEventListener("change", (e) => handleFileInputChange(e));
|
|
143
|
+
}, children: "Select file(s)" }),
|
|
144
|
+
/* @__PURE__ */ jsx("div", { style: { maxWidth: 400 }, children: "Playwright Trace Viewer is a Progressive Web App, it does not send your trace anywhere, it opens it locally." })
|
|
145
|
+
] }),
|
|
146
|
+
isServer && !traceURLs.length && /* @__PURE__ */ jsx("div", { className: "drop-target", children: /* @__PURE__ */ jsx("div", { className: "title", children: "Select test to see the trace" }) }),
|
|
147
|
+
dragOver && /* @__PURE__ */ jsx(
|
|
148
|
+
"div",
|
|
149
|
+
{
|
|
150
|
+
className: "drop-target",
|
|
151
|
+
onDragLeave: () => {
|
|
152
|
+
setDragOver(false);
|
|
153
|
+
},
|
|
154
|
+
onDrop: (event) => handleDropEvent(event),
|
|
155
|
+
children: /* @__PURE__ */ jsx("div", { className: "title", children: "Release to analyse the Playwright Trace" })
|
|
156
|
+
}
|
|
157
|
+
)
|
|
158
|
+
] });
|
|
159
|
+
};
|
|
160
|
+
const emptyModel = new MultiTraceModel([]);
|
|
161
|
+
(async () => {
|
|
162
|
+
applyTheme();
|
|
163
|
+
if (window.location.protocol !== "file:") {
|
|
164
|
+
if (window.location.href.includes("isUnderTest=true"))
|
|
165
|
+
await new Promise((f) => setTimeout(f, 1e3));
|
|
166
|
+
if (!navigator.serviceWorker)
|
|
167
|
+
throw new Error(`Service workers are not supported.
|
|
168
|
+
Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);
|
|
169
|
+
navigator.serviceWorker.register("sw.bundle.js");
|
|
170
|
+
if (!navigator.serviceWorker.controller) {
|
|
171
|
+
await new Promise((f) => {
|
|
172
|
+
navigator.serviceWorker.oncontrollerchange = () => f();
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
setInterval(function() {
|
|
176
|
+
fetch("ping");
|
|
177
|
+
}, 1e4);
|
|
178
|
+
}
|
|
179
|
+
reactDomExports.render(/* @__PURE__ */ jsx(WorkbenchLoader, {}), document.querySelector("#root"));
|
|
180
|
+
})();
|
|
181
|
+
//# sourceMappingURL=index.e8730524.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{M as E,r as s,c as R,j as c,a as r,T as x,t as C,W as j,b as F,d as O}from"./assets/wsPort-762c6840.js";const I=()=>{const[l,P]=s.useState(!1),[d,h]=s.useState([]),[p,W]=s.useState([]),[v,S]=s.useState(L),[f,m]=s.useState({done:0,total:0}),[b,g]=s.useState(!1),[k,w]=s.useState(null),[T,U]=s.useState(null),u=s.useCallback(e=>{const o=[],a=[],t=new URL(window.location.href);for(let i=0;i<e.length;i++){const n=e.item(i);if(!n)continue;const N=URL.createObjectURL(n);o.push(N),a.push(n.name),t.searchParams.append("trace",N),t.searchParams.append("traceFileName",n.name)}const y=t.toString();window.history.pushState({},"",y),h(o),W(a),g(!1),w(null)},[]),D=s.useCallback(e=>{e.preventDefault(),u(e.dataTransfer.files)},[u]),M=s.useCallback(e=>{e.preventDefault(),e.target.files&&u(e.target.files)},[u]);return s.useEffect(()=>{const e=new URL(window.location.href).searchParams,o=e.getAll("trace");P(e.has("isServer"));for(const a of o)if(a.startsWith("file:")){U(a||null);return}e.has("isServer")?R({onEvent(a,t){a==="loadTrace"&&(h(t.url?[t.url]:[]),g(!1),w(null))},onClose(){}}).then(a=>{a("ready")}):o.some(a=>a.startsWith("blob:"))||h(o)},[]),s.useEffect(()=>{(async()=>{if(d.length){const e=t=>{t.data.method==="progress"&&m(t.data.params)};navigator.serviceWorker.addEventListener("message",e),m({done:0,total:1});const o=[];for(let t=0;t<d.length;t++){const y=d[t],i=new URLSearchParams;i.set("trace",y),p.length&&i.set("traceFileName",p[t]);const n=await fetch(`contexts?${i.toString()}`);if(!n.ok){l||h([]),w((await n.json()).error);return}o.push(...await n.json())}navigator.serviceWorker.removeEventListener("message",e);const a=new E(o);m({done:0,total:0}),S(a)}else S(L)})()},[l,d,p]),c("div",{className:"vbox workbench-loader",onDragOver:e=>{e.preventDefault(),g(!0)},children:[c("div",{className:"hbox header",children:[r("div",{className:"logo",children:r("img",{src:"playwright-logo.svg",alt:"Playwright logo"})}),r("div",{className:"product",children:"Playwright"}),v.title&&r("div",{className:"title",children:v.title}),r("div",{className:"spacer"}),r(x,{icon:"color-mode",title:"Toggle color mode",toggled:!1,onClick:()=>C()})]}),r("div",{className:"progress",children:r("div",{className:"inner-progress",style:{width:f.total?100*f.done/f.total+"%":0}})}),r(j,{model:v}),T&&c("div",{className:"drop-target",children:[r("div",{children:"Trace Viewer uses Service Workers to show traces. To view trace:"}),c("div",{style:{paddingTop:20},children:[c("div",{children:["1. Click ",r("a",{href:T,children:"here"})," to put your trace into the download shelf"]}),c("div",{children:["2. Go to ",r("a",{href:"https://trace.playwright.dev",children:"trace.playwright.dev"})]}),r("div",{children:"3. Drop the trace from the download shelf into the page"})]})]}),!l&&!b&&!T&&(!d.length||k)&&c("div",{className:"drop-target",children:[r("div",{className:"processing-error",children:k}),r("div",{className:"title",children:"Drop Playwright Trace to load"}),r("div",{children:"or"}),r("button",{onClick:()=>{const e=document.createElement("input");e.type="file",e.multiple=!0,e.click(),e.addEventListener("change",o=>M(o))},children:"Select file(s)"}),r("div",{style:{maxWidth:400},children:"Playwright Trace Viewer is a Progressive Web App, it does not send your trace anywhere, it opens it locally."})]}),l&&!d.length&&r("div",{className:"drop-target",children:r("div",{className:"title",children:"Select test to see the trace"})}),b&&r("div",{className:"drop-target",onDragLeave:()=>{g(!1)},onDrop:e=>D(e),children:r("div",{className:"title",children:"Release to analyse the Playwright Trace"})})]})},L=new E([]);(async()=>{if(F(),window.location.protocol!=="file:"){if(window.location.href.includes("isUnderTest=true")&&await new Promise(l=>setTimeout(l,1e3)),!navigator.serviceWorker)throw new Error(`Service workers are not supported.
|
|
2
|
+
Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);navigator.serviceWorker.register("sw.bundle.js"),navigator.serviceWorker.controller||await new Promise(l=>{navigator.serviceWorker.oncontrollerchange=()=>l()}),setInterval(function(){fetch("ping")},1e4)}O.render(r(I,{}),document.querySelector("#root"))})();
|
|
@@ -7,9 +7,9 @@
|
|
|
7
7
|
<link rel="icon" href="./playwright-logo.svg" type="image/svg+xml">
|
|
8
8
|
<link rel="manifest" href="./manifest.webmanifest">
|
|
9
9
|
<title>Playwright Trace Viewer</title>
|
|
10
|
-
<script type="module" crossorigin src="./index.
|
|
11
|
-
<link rel="modulepreload" crossorigin href="./assets/inspectorTab-
|
|
12
|
-
<link rel="modulepreload" crossorigin href="./assets/workbench-
|
|
10
|
+
<script type="module" crossorigin src="./index.DPD22sZn.js"></script>
|
|
11
|
+
<link rel="modulepreload" crossorigin href="./assets/inspectorTab-BPzhNk9r.js">
|
|
12
|
+
<link rel="modulepreload" crossorigin href="./assets/workbench-DLv_q9ji.js">
|
|
13
13
|
<link rel="modulepreload" crossorigin href="./assets/testServerConnection-DeE2kSzz.js">
|
|
14
14
|
<link rel="stylesheet" crossorigin href="./inspectorTab.DLjBDrQR.css">
|
|
15
15
|
<link rel="stylesheet" crossorigin href="./workbench.DlsCx8k5.css">
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
var __defProp = Object.defineProperty;
|
|
2
2
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
3
|
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
4
|
-
import { j as jsxRuntimeExports, r as reactExports, M as MultiTraceModel, F as sha1, n as asLocator, L as ListView, g as Toolbar, T as ToolbarButton, H as ToolbarSeparator, J as copy, t as toggleTheme, S as SplitView, D as TabbedPane, y as useConsoleTabModel, z as useNetworkTabModel, h as useSetting, A as ConsoleTab, N as NetworkTab, K as collectSnapshots, O as extendSnapshot, Q as SnapshotView, I as InspectorTab, E as SourceTab, a as applyTheme, c as createRoot } from "./assets/inspectorTab-
|
|
4
|
+
import { j as jsxRuntimeExports, r as reactExports, M as MultiTraceModel, F as sha1, n as asLocator, L as ListView, g as Toolbar, T as ToolbarButton, H as ToolbarSeparator, J as copy, t as toggleTheme, S as SplitView, D as TabbedPane, y as useConsoleTabModel, z as useNetworkTabModel, h as useSetting, A as ConsoleTab, N as NetworkTab, K as collectSnapshots, O as extendSnapshot, Q as SnapshotView, I as InspectorTab, E as SourceTab, a as applyTheme, c as createRoot } from "./assets/inspectorTab-B4ynvyY9.js";
|
|
5
5
|
const SourceChooser = ({ sources, fileId, setFileId }) => {
|
|
6
6
|
return /* @__PURE__ */ jsxRuntimeExports.jsx("select", { className: "source-chooser", hidden: !sources.length, title: "Source chooser", value: fileId, onChange: (event) => {
|
|
7
7
|
setFileId(event.target.selectedOptions[0].value);
|
|
@@ -50,6 +50,7 @@ const ModelProvider = ({ trace, children }) => {
|
|
|
50
50
|
async function loadSingleTraceFile(url) {
|
|
51
51
|
const params = new URLSearchParams();
|
|
52
52
|
params.set("trace", url);
|
|
53
|
+
params.set("limit", "1");
|
|
53
54
|
const response = await fetch(`contexts?${params.toString()}`);
|
|
54
55
|
const contextEntries = await response.json();
|
|
55
56
|
const tokens = [];
|
|
@@ -547,4 +548,4 @@ Make sure to serve the Recorder (${window.location}) via HTTPS or localhost.`);
|
|
|
547
548
|
}
|
|
548
549
|
createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(RecorderView, {}));
|
|
549
550
|
})();
|
|
550
|
-
//# sourceMappingURL=recorder.
|
|
551
|
+
//# sourceMappingURL=recorder.3Xfrl_zV.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
var __defProp = Object.defineProperty;
|
|
2
2
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
3
|
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
4
|
-
import { j as jsxRuntimeExports, r as reactExports, M as MultiTraceModel, F as sha1, n as asLocator, L as ListView, g as Toolbar, T as ToolbarButton, H as ToolbarSeparator, J as copy, t as toggleTheme, S as SplitView, D as TabbedPane, y as useConsoleTabModel, z as useNetworkTabModel, h as useSetting, A as ConsoleTab, N as NetworkTab, K as collectSnapshots, O as extendSnapshot, Q as SnapshotView, I as InspectorTab, E as SourceTab, a as applyTheme, c as createRoot } from "./assets/inspectorTab-
|
|
4
|
+
import { j as jsxRuntimeExports, r as reactExports, M as MultiTraceModel, F as sha1, n as asLocator, L as ListView, g as Toolbar, T as ToolbarButton, H as ToolbarSeparator, J as copy, t as toggleTheme, S as SplitView, D as TabbedPane, y as useConsoleTabModel, z as useNetworkTabModel, h as useSetting, A as ConsoleTab, N as NetworkTab, K as collectSnapshots, O as extendSnapshot, Q as SnapshotView, I as InspectorTab, E as SourceTab, a as applyTheme, c as createRoot } from "./assets/inspectorTab-CHcHvp_a.js";
|
|
5
5
|
const SourceChooser = ({ sources, fileId, setFileId }) => {
|
|
6
6
|
return /* @__PURE__ */ jsxRuntimeExports.jsx("select", { className: "source-chooser", hidden: !sources.length, title: "Source chooser", value: fileId, onChange: (event) => {
|
|
7
7
|
setFileId(event.target.selectedOptions[0].value);
|
|
@@ -50,6 +50,7 @@ const ModelProvider = ({ trace, children }) => {
|
|
|
50
50
|
async function loadSingleTraceFile(url) {
|
|
51
51
|
const params = new URLSearchParams();
|
|
52
52
|
params.set("trace", url);
|
|
53
|
+
params.set("limit", "1");
|
|
53
54
|
const response = await fetch(`contexts?${params.toString()}`);
|
|
54
55
|
const contextEntries = await response.json();
|
|
55
56
|
const tokens = [];
|
|
@@ -547,4 +548,4 @@ Make sure to serve the Recorder (${window.location}) via HTTPS or localhost.`);
|
|
|
547
548
|
}
|
|
548
549
|
createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(RecorderView, {}));
|
|
549
550
|
})();
|
|
550
|
-
//# sourceMappingURL=recorder.
|
|
551
|
+
//# sourceMappingURL=recorder.BWH6blRw.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
var __defProp = Object.defineProperty;
|
|
2
2
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
3
|
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
4
|
-
import { j as jsxRuntimeExports, r as reactExports, M as MultiTraceModel, F as sha1, n as asLocator, L as ListView, g as Toolbar, T as ToolbarButton, H as ToolbarSeparator, J as copy, t as toggleTheme, S as SplitView, D as TabbedPane, y as useConsoleTabModel, z as useNetworkTabModel, h as useSetting, A as ConsoleTab, N as NetworkTab, K as collectSnapshots, O as extendSnapshot, Q as SnapshotView, I as InspectorTab, E as SourceTab, a as applyTheme, c as createRoot } from "./assets/inspectorTab-
|
|
4
|
+
import { j as jsxRuntimeExports, r as reactExports, M as MultiTraceModel, F as sha1, n as asLocator, L as ListView, g as Toolbar, T as ToolbarButton, H as ToolbarSeparator, J as copy, t as toggleTheme, S as SplitView, D as TabbedPane, y as useConsoleTabModel, z as useNetworkTabModel, h as useSetting, A as ConsoleTab, N as NetworkTab, K as collectSnapshots, O as extendSnapshot, Q as SnapshotView, I as InspectorTab, E as SourceTab, a as applyTheme, c as createRoot } from "./assets/inspectorTab-Dw0Gnh1T.js";
|
|
5
5
|
const SourceChooser = ({ sources, fileId, setFileId }) => {
|
|
6
6
|
return /* @__PURE__ */ jsxRuntimeExports.jsx("select", { className: "source-chooser", hidden: !sources.length, title: "Source chooser", value: fileId, onChange: (event) => {
|
|
7
7
|
setFileId(event.target.selectedOptions[0].value);
|
|
@@ -50,6 +50,7 @@ const ModelProvider = ({ trace, children }) => {
|
|
|
50
50
|
async function loadSingleTraceFile(url) {
|
|
51
51
|
const params = new URLSearchParams();
|
|
52
52
|
params.set("trace", url);
|
|
53
|
+
params.set("limit", "1");
|
|
53
54
|
const response = await fetch(`contexts?${params.toString()}`);
|
|
54
55
|
const contextEntries = await response.json();
|
|
55
56
|
const tokens = [];
|
|
@@ -547,4 +548,4 @@ Make sure to serve the Recorder (${window.location}) via HTTPS or localhost.`);
|
|
|
547
548
|
}
|
|
548
549
|
createRoot(document.querySelector("#root")).render(/* @__PURE__ */ jsxRuntimeExports.jsx(RecorderView, {}));
|
|
549
550
|
})();
|
|
550
|
-
//# sourceMappingURL=recorder.
|
|
551
|
+
//# sourceMappingURL=recorder.Db1aK_DY.js.map
|
|
@@ -6,8 +6,8 @@
|
|
|
6
6
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
7
7
|
<link rel="icon" href="./playwright-logo.svg" type="image/svg+xml">
|
|
8
8
|
<title>Playwright Recorder</title>
|
|
9
|
-
<script type="module" crossorigin src="./recorder.
|
|
10
|
-
<link rel="modulepreload" crossorigin href="./assets/inspectorTab-
|
|
9
|
+
<script type="module" crossorigin src="./recorder.BaRuS6Pc.js"></script>
|
|
10
|
+
<link rel="modulepreload" crossorigin href="./assets/inspectorTab-BPzhNk9r.js">
|
|
11
11
|
<link rel="stylesheet" crossorigin href="./inspectorTab.DLjBDrQR.css">
|
|
12
12
|
<link rel="stylesheet" crossorigin href="./recorder.B_SY1GJM.css">
|
|
13
13
|
</head>
|