@checkly/playwright-core 1.42.12 → 1.42.13
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/sWatcher.js +150 -0
- package/lib/cli/cli.js +62 -0
- package/lib/client/channelOwner.js +1 -1
- package/lib/client/fetch.js +9 -5
- package/lib/common/debugLogger.js +91 -0
- package/lib/generated/consoleApiSource.js +2 -1
- package/lib/generated/injectedScriptSource.js +2 -1
- package/lib/generated/recorderSource.js +2 -1
- package/lib/generated/utilityScriptSource.js +2 -1
- package/lib/vite/recorder/assets/codeMirrorModule-XkYKvQWL.js +15585 -0
- package/lib/vite/recorder/assets/codeMirrorModule-svF_VrcJ.css +344 -0
- package/lib/vite/recorder/assets/index-Sgxgm22s.css +2455 -0
- package/lib/vite/recorder/assets/index-g7JXfYxX.js +10429 -0
- package/lib/vite/recorder/index.html +2 -2
- package/lib/vite/traceViewer/assets/{codeMirrorModule-Vg1kIqMp.js → codeMirrorModule-0bpaqixv.js} +10 -10
- package/lib/vite/traceViewer/assets/codeMirrorModule-5nkjDDU_.js +15578 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-75b0ca4f.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-RVP_AMUu.js +15585 -0
- package/lib/vite/{recorder/assets/codeMirrorModule-I9ks4y7D.js → traceViewer/assets/codeMirrorModule-c1454a2e.js} +10 -10
- package/lib/vite/traceViewer/assets/codeMirrorModule-cc2329e4.js +15593 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-d725feea.js +15586 -0
- package/lib/vite/traceViewer/assets/{codeMirrorModule-wLpsbIhd.js → codeMirrorModule-e5a15eec.js} +13 -13
- package/lib/vite/traceViewer/assets/codeMirrorModule-kT-uS7F4.js +15592 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-rcsC5no8.js +15592 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-yboVpgC0.js +15592 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-ytMY1awF.js +15585 -0
- package/lib/vite/traceViewer/assets/wsPort-1-6TL4lc.js +18540 -0
- package/lib/vite/traceViewer/assets/wsPort-54626118.js +18361 -0
- package/lib/vite/traceViewer/assets/wsPort-98e00a94.js +64 -0
- package/lib/vite/traceViewer/assets/wsPort-CAXygIGt.js +18540 -0
- package/lib/vite/traceViewer/assets/wsPort-KEbz4l8i.js +18540 -0
- package/lib/vite/traceViewer/assets/{wsPort-RIoVGhlT.js → wsPort-_JBDEilC.js} +2 -2
- package/lib/vite/traceViewer/assets/wsPort-a88a6a12.js +18361 -0
- package/lib/vite/traceViewer/assets/wsPort-cb764cde.js +64 -0
- package/lib/vite/traceViewer/assets/wsPort-ee2830d7.js +64 -0
- package/lib/vite/traceViewer/assets/wsPort-lTlmZhJd.js +18564 -0
- package/lib/vite/traceViewer/assets/wsPort-xpIMLVfx.js +18540 -0
- package/lib/vite/traceViewer/assets/wsPort-yM58htfg.js +18360 -0
- 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/index.1a1fe659.css +1 -0
- package/lib/vite/traceViewer/index.4a8ee36e.js +2 -0
- package/lib/vite/traceViewer/index.55e65778.js +181 -0
- package/lib/vite/traceViewer/index.5nqVcfiC.js +180 -0
- package/lib/vite/traceViewer/index.742fd3e5.js +181 -0
- package/lib/vite/traceViewer/index.76e9f312.css +124 -0
- package/lib/vite/traceViewer/index.UNF4A0jZ.js +180 -0
- package/lib/vite/traceViewer/index.ZUjC4zt1.js +180 -0
- package/lib/vite/traceViewer/index.a265fbdb.js +2 -0
- package/lib/vite/traceViewer/index.decad628.js +2 -0
- package/lib/vite/traceViewer/index.html +4 -4
- package/lib/vite/traceViewer/index.ici1bqta.js +180 -0
- package/lib/vite/traceViewer/index.mxOcKqpu.js +180 -0
- package/lib/vite/traceViewer/{index.-_8-eHEE.js → index.u51inEcm.js} +1 -1
- package/lib/vite/traceViewer/index.zXVxM5ps.js +180 -0
- package/lib/vite/traceViewer/sw.bundle.js +7403 -4
- 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.2c31018f.css +1324 -0
- package/lib/vite/traceViewer/uiMode.468b0309.js +4 -0
- package/lib/vite/traceViewer/uiMode.67C8Ij-c.js +1490 -0
- package/lib/vite/traceViewer/uiMode.8b41a49d.css +1 -0
- package/lib/vite/traceViewer/uiMode.F_k6a2aC.js +1488 -0
- package/lib/vite/traceViewer/{uiMode.9CwNsWc6.js → uiMode.Fb0bNA4H.js} +1 -1
- package/lib/vite/traceViewer/uiMode.NjZAwD_B.js +1485 -0
- package/lib/vite/traceViewer/uiMode.YQRCZjm8.js +1485 -0
- package/lib/vite/traceViewer/uiMode.b2068d00.js +1484 -0
- package/lib/vite/traceViewer/uiMode.e-PLonGl.js +1490 -0
- package/lib/vite/traceViewer/uiMode.fEEgOxJh.js +1490 -0
- package/lib/vite/traceViewer/uiMode.html +4 -4
- package/lib/vite/traceViewer/uiMode.kvEeWpo2.js +1490 -0
- package/lib/vite/traceViewer/uiMode.ljHA9Ynz.js +1490 -0
- package/lib/vite/traceViewer/uiMode.ybQP_6Xr.js +10 -0
- package/lib/vite/traceViewer/wsPort.997c92cf.css +3513 -0
- package/lib/vite/traceViewer/wsPort.9c9a6767.css +1 -0
- package/lib/vite/traceViewer/wsPort.Oa05jfrO.css +3513 -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-Hs9-1ZG4.css +0 -1
- package/lib/vite/recorder/assets/index-ljsTwXtJ.css +0 -1
- package/lib/vite/recorder/assets/index-yg8ypzl6.js +0 -47
- package/lib/vite/traceViewer/assets/wsPort-f2dAQL4I.js +0 -69
- package/lib/vite/traceViewer/index.qOFdH9Ja.js +0 -2
- package/lib/vite/traceViewer/uiMode.iNIhieBM.js +0 -10
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { M as MultiTraceModel, r as reactExports, c as connect, j as jsxRuntimeExports, T as ToolbarButton, t as toggleTheme, W as Workbench, a as applyTheme, b as reactDomExports } from "./assets/wsPort-yM58htfg.js";
|
|
2
|
+
const WorkbenchLoader = () => {
|
|
3
|
+
const [isServer, setIsServer] = reactExports.useState(false);
|
|
4
|
+
const [traceURLs, setTraceURLs] = reactExports.useState([]);
|
|
5
|
+
const [uploadedTraceNames, setUploadedTraceNames] = reactExports.useState([]);
|
|
6
|
+
const [model, setModel] = reactExports.useState(emptyModel);
|
|
7
|
+
const [progress, setProgress] = reactExports.useState({ done: 0, total: 0 });
|
|
8
|
+
const [dragOver, setDragOver] = reactExports.useState(false);
|
|
9
|
+
const [processingErrorMessage, setProcessingErrorMessage] = reactExports.useState(null);
|
|
10
|
+
const [fileForLocalModeError, setFileForLocalModeError] = reactExports.useState(null);
|
|
11
|
+
const processTraceFiles = reactExports.useCallback((files) => {
|
|
12
|
+
const blobUrls = [];
|
|
13
|
+
const fileNames = [];
|
|
14
|
+
const url = new URL(window.location.href);
|
|
15
|
+
for (let i = 0; i < files.length; i++) {
|
|
16
|
+
const file = files.item(i);
|
|
17
|
+
if (!file)
|
|
18
|
+
continue;
|
|
19
|
+
const blobTraceURL = URL.createObjectURL(file);
|
|
20
|
+
blobUrls.push(blobTraceURL);
|
|
21
|
+
fileNames.push(file.name);
|
|
22
|
+
url.searchParams.append("trace", blobTraceURL);
|
|
23
|
+
url.searchParams.append("traceFileName", file.name);
|
|
24
|
+
}
|
|
25
|
+
const href = url.toString();
|
|
26
|
+
window.history.pushState({}, "", href);
|
|
27
|
+
setTraceURLs(blobUrls);
|
|
28
|
+
setUploadedTraceNames(fileNames);
|
|
29
|
+
setDragOver(false);
|
|
30
|
+
setProcessingErrorMessage(null);
|
|
31
|
+
}, []);
|
|
32
|
+
const handleDropEvent = reactExports.useCallback((event) => {
|
|
33
|
+
event.preventDefault();
|
|
34
|
+
processTraceFiles(event.dataTransfer.files);
|
|
35
|
+
}, [processTraceFiles]);
|
|
36
|
+
const handleFileInputChange = reactExports.useCallback((event) => {
|
|
37
|
+
event.preventDefault();
|
|
38
|
+
if (!event.target.files)
|
|
39
|
+
return;
|
|
40
|
+
processTraceFiles(event.target.files);
|
|
41
|
+
}, [processTraceFiles]);
|
|
42
|
+
reactExports.useEffect(() => {
|
|
43
|
+
const params = new URL(window.location.href).searchParams;
|
|
44
|
+
const newTraceURLs = params.getAll("trace");
|
|
45
|
+
setIsServer(params.has("isServer"));
|
|
46
|
+
for (const url of newTraceURLs) {
|
|
47
|
+
if (url.startsWith("file:")) {
|
|
48
|
+
setFileForLocalModeError(url || null);
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
if (params.has("isServer")) {
|
|
53
|
+
connect({
|
|
54
|
+
onEvent(method, params2) {
|
|
55
|
+
if (method === "loadTrace") {
|
|
56
|
+
setTraceURLs(params2.url ? [params2.url] : []);
|
|
57
|
+
setDragOver(false);
|
|
58
|
+
setProcessingErrorMessage(null);
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
onClose() {
|
|
62
|
+
}
|
|
63
|
+
}).then((sendMessage) => {
|
|
64
|
+
sendMessage("ready");
|
|
65
|
+
});
|
|
66
|
+
} else if (!newTraceURLs.some((url) => url.startsWith("blob:"))) {
|
|
67
|
+
setTraceURLs(newTraceURLs);
|
|
68
|
+
}
|
|
69
|
+
}, []);
|
|
70
|
+
reactExports.useEffect(() => {
|
|
71
|
+
(async () => {
|
|
72
|
+
if (traceURLs.length) {
|
|
73
|
+
const swListener = (event) => {
|
|
74
|
+
if (event.data.method === "progress")
|
|
75
|
+
setProgress(event.data.params);
|
|
76
|
+
};
|
|
77
|
+
navigator.serviceWorker.addEventListener("message", swListener);
|
|
78
|
+
setProgress({ done: 0, total: 1 });
|
|
79
|
+
const contextEntries = [];
|
|
80
|
+
for (let i = 0; i < traceURLs.length; i++) {
|
|
81
|
+
const url = traceURLs[i];
|
|
82
|
+
const params = new URLSearchParams();
|
|
83
|
+
params.set("trace", url);
|
|
84
|
+
if (uploadedTraceNames.length)
|
|
85
|
+
params.set("traceFileName", uploadedTraceNames[i]);
|
|
86
|
+
const response = await fetch(`contexts?${params.toString()}`);
|
|
87
|
+
if (!response.ok) {
|
|
88
|
+
if (!isServer)
|
|
89
|
+
setTraceURLs([]);
|
|
90
|
+
setProcessingErrorMessage((await response.json()).error);
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
contextEntries.push(...await response.json());
|
|
94
|
+
}
|
|
95
|
+
navigator.serviceWorker.removeEventListener("message", swListener);
|
|
96
|
+
const model2 = new MultiTraceModel(contextEntries);
|
|
97
|
+
setProgress({ done: 0, total: 0 });
|
|
98
|
+
setModel(model2);
|
|
99
|
+
} else {
|
|
100
|
+
setModel(emptyModel);
|
|
101
|
+
}
|
|
102
|
+
})();
|
|
103
|
+
}, [isServer, traceURLs, uploadedTraceNames]);
|
|
104
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "vbox workbench-loader", onDragOver: (event) => {
|
|
105
|
+
event.preventDefault();
|
|
106
|
+
setDragOver(true);
|
|
107
|
+
}, children: [
|
|
108
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "hbox header", children: [
|
|
109
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "logo", children: /* @__PURE__ */ jsxRuntimeExports.jsx("img", { src: "playwright-logo.svg", alt: "Playwright logo" }) }),
|
|
110
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "product", children: "Playwright" }),
|
|
111
|
+
model.title && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: model.title }),
|
|
112
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "spacer" }),
|
|
113
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(ToolbarButton, { icon: "color-mode", title: "Toggle color mode", toggled: false, onClick: () => toggleTheme() })
|
|
114
|
+
] }),
|
|
115
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "progress", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "inner-progress", style: { width: progress.total ? 100 * progress.done / progress.total + "%" : 0 } }) }),
|
|
116
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(Workbench, { model }),
|
|
117
|
+
fileForLocalModeError && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
|
|
118
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "Trace Viewer uses Service Workers to show traces. To view trace:" }),
|
|
119
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { style: { paddingTop: 20 }, children: [
|
|
120
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
|
|
121
|
+
"1. Click ",
|
|
122
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: fileForLocalModeError, children: "here" }),
|
|
123
|
+
" to put your trace into the download shelf"
|
|
124
|
+
] }),
|
|
125
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs("div", { children: [
|
|
126
|
+
"2. Go to ",
|
|
127
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: "https://trace.playwright.dev", children: "trace.playwright.dev" })
|
|
128
|
+
] }),
|
|
129
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "3. Drop the trace from the download shelf into the page" })
|
|
130
|
+
] })
|
|
131
|
+
] }),
|
|
132
|
+
!isServer && !dragOver && !fileForLocalModeError && (!traceURLs.length || processingErrorMessage) && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "drop-target", children: [
|
|
133
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "processing-error", children: processingErrorMessage }),
|
|
134
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Drop Playwright Trace to load" }),
|
|
135
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: "or" }),
|
|
136
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("button", { onClick: () => {
|
|
137
|
+
const input = document.createElement("input");
|
|
138
|
+
input.type = "file";
|
|
139
|
+
input.multiple = true;
|
|
140
|
+
input.click();
|
|
141
|
+
input.addEventListener("change", (e) => handleFileInputChange(e));
|
|
142
|
+
}, children: "Select file(s)" }),
|
|
143
|
+
/* @__PURE__ */ jsxRuntimeExports.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." })
|
|
144
|
+
] }),
|
|
145
|
+
isServer && !traceURLs.length && /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "drop-target", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Select test to see the trace" }) }),
|
|
146
|
+
dragOver && /* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
147
|
+
"div",
|
|
148
|
+
{
|
|
149
|
+
className: "drop-target",
|
|
150
|
+
onDragLeave: () => {
|
|
151
|
+
setDragOver(false);
|
|
152
|
+
},
|
|
153
|
+
onDrop: (event) => handleDropEvent(event),
|
|
154
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "title", children: "Release to analyse the Playwright Trace" })
|
|
155
|
+
}
|
|
156
|
+
)
|
|
157
|
+
] });
|
|
158
|
+
};
|
|
159
|
+
const emptyModel = new MultiTraceModel([]);
|
|
160
|
+
(async () => {
|
|
161
|
+
applyTheme();
|
|
162
|
+
if (window.location.protocol !== "file:") {
|
|
163
|
+
if (window.location.href.includes("isUnderTest=true"))
|
|
164
|
+
await new Promise((f) => setTimeout(f, 1e3));
|
|
165
|
+
if (!navigator.serviceWorker)
|
|
166
|
+
throw new Error(`Service workers are not supported.
|
|
167
|
+
Make sure to serve the Trace Viewer (${window.location}) via HTTPS or localhost.`);
|
|
168
|
+
navigator.serviceWorker.register("sw.bundle.js");
|
|
169
|
+
if (!navigator.serviceWorker.controller) {
|
|
170
|
+
await new Promise((f) => {
|
|
171
|
+
navigator.serviceWorker.oncontrollerchange = () => f();
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
setInterval(function() {
|
|
175
|
+
fetch("ping");
|
|
176
|
+
}, 1e4);
|
|
177
|
+
}
|
|
178
|
+
reactDomExports.render(/* @__PURE__ */ jsxRuntimeExports.jsx(WorkbenchLoader, {}), document.querySelector("#root"));
|
|
179
|
+
})();
|
|
180
|
+
//# sourceMappingURL=index.zXVxM5ps.js.map
|