@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.
Files changed (89) hide show
  1. package/lib/checkly/sWatcher.js +150 -0
  2. package/lib/cli/cli.js +62 -0
  3. package/lib/client/channelOwner.js +1 -1
  4. package/lib/client/fetch.js +9 -5
  5. package/lib/common/debugLogger.js +91 -0
  6. package/lib/generated/consoleApiSource.js +2 -1
  7. package/lib/generated/injectedScriptSource.js +2 -1
  8. package/lib/generated/recorderSource.js +2 -1
  9. package/lib/generated/utilityScriptSource.js +2 -1
  10. package/lib/vite/recorder/assets/codeMirrorModule-XkYKvQWL.js +15585 -0
  11. package/lib/vite/recorder/assets/codeMirrorModule-svF_VrcJ.css +344 -0
  12. package/lib/vite/recorder/assets/index-Sgxgm22s.css +2455 -0
  13. package/lib/vite/recorder/assets/index-g7JXfYxX.js +10429 -0
  14. package/lib/vite/recorder/index.html +2 -2
  15. package/lib/vite/traceViewer/assets/{codeMirrorModule-Vg1kIqMp.js → codeMirrorModule-0bpaqixv.js} +10 -10
  16. package/lib/vite/traceViewer/assets/codeMirrorModule-5nkjDDU_.js +15578 -0
  17. package/lib/vite/traceViewer/assets/codeMirrorModule-75b0ca4f.js +24 -0
  18. package/lib/vite/traceViewer/assets/codeMirrorModule-RVP_AMUu.js +15585 -0
  19. package/lib/vite/{recorder/assets/codeMirrorModule-I9ks4y7D.js → traceViewer/assets/codeMirrorModule-c1454a2e.js} +10 -10
  20. package/lib/vite/traceViewer/assets/codeMirrorModule-cc2329e4.js +15593 -0
  21. package/lib/vite/traceViewer/assets/codeMirrorModule-d725feea.js +15586 -0
  22. package/lib/vite/traceViewer/assets/{codeMirrorModule-wLpsbIhd.js → codeMirrorModule-e5a15eec.js} +13 -13
  23. package/lib/vite/traceViewer/assets/codeMirrorModule-kT-uS7F4.js +15592 -0
  24. package/lib/vite/traceViewer/assets/codeMirrorModule-rcsC5no8.js +15592 -0
  25. package/lib/vite/traceViewer/assets/codeMirrorModule-yboVpgC0.js +15592 -0
  26. package/lib/vite/traceViewer/assets/codeMirrorModule-ytMY1awF.js +15585 -0
  27. package/lib/vite/traceViewer/assets/wsPort-1-6TL4lc.js +18540 -0
  28. package/lib/vite/traceViewer/assets/wsPort-54626118.js +18361 -0
  29. package/lib/vite/traceViewer/assets/wsPort-98e00a94.js +64 -0
  30. package/lib/vite/traceViewer/assets/wsPort-CAXygIGt.js +18540 -0
  31. package/lib/vite/traceViewer/assets/wsPort-KEbz4l8i.js +18540 -0
  32. package/lib/vite/traceViewer/assets/{wsPort-RIoVGhlT.js → wsPort-_JBDEilC.js} +2 -2
  33. package/lib/vite/traceViewer/assets/wsPort-a88a6a12.js +18361 -0
  34. package/lib/vite/traceViewer/assets/wsPort-cb764cde.js +64 -0
  35. package/lib/vite/traceViewer/assets/wsPort-ee2830d7.js +64 -0
  36. package/lib/vite/traceViewer/assets/wsPort-lTlmZhJd.js +18564 -0
  37. package/lib/vite/traceViewer/assets/wsPort-xpIMLVfx.js +18540 -0
  38. package/lib/vite/traceViewer/assets/wsPort-yM58htfg.js +18360 -0
  39. package/lib/vite/traceViewer/assets/xtermModule-443332e6.js +9 -0
  40. package/lib/vite/traceViewer/assets/xtermModule-60687b6b.js +6410 -0
  41. package/lib/vite/traceViewer/codeMirrorModule.5d0f417c.css +1 -0
  42. package/lib/vite/traceViewer/codeMirrorModule.eb494ea9.css +344 -0
  43. package/lib/vite/traceViewer/codicon.79f233d0.ttf +0 -0
  44. package/lib/vite/traceViewer/index.1a1fe659.css +1 -0
  45. package/lib/vite/traceViewer/index.4a8ee36e.js +2 -0
  46. package/lib/vite/traceViewer/index.55e65778.js +181 -0
  47. package/lib/vite/traceViewer/index.5nqVcfiC.js +180 -0
  48. package/lib/vite/traceViewer/index.742fd3e5.js +181 -0
  49. package/lib/vite/traceViewer/index.76e9f312.css +124 -0
  50. package/lib/vite/traceViewer/index.UNF4A0jZ.js +180 -0
  51. package/lib/vite/traceViewer/index.ZUjC4zt1.js +180 -0
  52. package/lib/vite/traceViewer/index.a265fbdb.js +2 -0
  53. package/lib/vite/traceViewer/index.decad628.js +2 -0
  54. package/lib/vite/traceViewer/index.html +4 -4
  55. package/lib/vite/traceViewer/index.ici1bqta.js +180 -0
  56. package/lib/vite/traceViewer/index.mxOcKqpu.js +180 -0
  57. package/lib/vite/traceViewer/{index.-_8-eHEE.js → index.u51inEcm.js} +1 -1
  58. package/lib/vite/traceViewer/index.zXVxM5ps.js +180 -0
  59. package/lib/vite/traceViewer/sw.bundle.js +7403 -4
  60. package/lib/vite/traceViewer/uiMode.08ab2d90.js +4 -0
  61. package/lib/vite/traceViewer/uiMode.0d0d667b.js +4 -0
  62. package/lib/vite/traceViewer/uiMode.216233d5.js +1484 -0
  63. package/lib/vite/traceViewer/uiMode.2c31018f.css +1324 -0
  64. package/lib/vite/traceViewer/uiMode.468b0309.js +4 -0
  65. package/lib/vite/traceViewer/uiMode.67C8Ij-c.js +1490 -0
  66. package/lib/vite/traceViewer/uiMode.8b41a49d.css +1 -0
  67. package/lib/vite/traceViewer/uiMode.F_k6a2aC.js +1488 -0
  68. package/lib/vite/traceViewer/{uiMode.9CwNsWc6.js → uiMode.Fb0bNA4H.js} +1 -1
  69. package/lib/vite/traceViewer/uiMode.NjZAwD_B.js +1485 -0
  70. package/lib/vite/traceViewer/uiMode.YQRCZjm8.js +1485 -0
  71. package/lib/vite/traceViewer/uiMode.b2068d00.js +1484 -0
  72. package/lib/vite/traceViewer/uiMode.e-PLonGl.js +1490 -0
  73. package/lib/vite/traceViewer/uiMode.fEEgOxJh.js +1490 -0
  74. package/lib/vite/traceViewer/uiMode.html +4 -4
  75. package/lib/vite/traceViewer/uiMode.kvEeWpo2.js +1490 -0
  76. package/lib/vite/traceViewer/uiMode.ljHA9Ynz.js +1490 -0
  77. package/lib/vite/traceViewer/uiMode.ybQP_6Xr.js +10 -0
  78. package/lib/vite/traceViewer/wsPort.997c92cf.css +3513 -0
  79. package/lib/vite/traceViewer/wsPort.9c9a6767.css +1 -0
  80. package/lib/vite/traceViewer/wsPort.Oa05jfrO.css +3513 -0
  81. package/lib/vite/traceViewer/xtermModule.125f4259.css +191 -0
  82. package/lib/vite/traceViewer/xtermModule.6428296b.css +32 -0
  83. package/package.json +1 -1
  84. package/lib/vite/recorder/assets/codeMirrorModule-Hs9-1ZG4.css +0 -1
  85. package/lib/vite/recorder/assets/index-ljsTwXtJ.css +0 -1
  86. package/lib/vite/recorder/assets/index-yg8ypzl6.js +0 -47
  87. package/lib/vite/traceViewer/assets/wsPort-f2dAQL4I.js +0 -69
  88. package/lib/vite/traceViewer/index.qOFdH9Ja.js +0 -2
  89. 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