@checkly/playwright-core 1.42.18 → 1.47.20-alpha

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 (238) hide show
  1. package/ThirdPartyNotices.txt +144 -109
  2. package/browsers.json +15 -25
  3. package/lib/androidServerImpl.js +1 -1
  4. package/lib/browserServerImpl.js +1 -1
  5. package/lib/cli/driver.js +1 -3
  6. package/lib/cli/program.js +5 -10
  7. package/lib/client/android.js +1 -1
  8. package/lib/client/api.js +7 -0
  9. package/lib/client/browserContext.js +37 -5
  10. package/lib/client/browserType.js +19 -11
  11. package/lib/client/channelOwner.js +19 -16
  12. package/lib/client/clientInstrumentation.js +17 -7
  13. package/lib/client/clock.js +68 -0
  14. package/lib/client/connection.js +9 -6
  15. package/lib/client/electron.js +7 -5
  16. package/lib/client/elementHandle.js +44 -14
  17. package/lib/client/eventEmitter.js +314 -0
  18. package/lib/client/fetch.js +81 -28
  19. package/lib/client/frame.js +2 -4
  20. package/lib/client/jsHandle.js +7 -1
  21. package/lib/client/locator.js +9 -0
  22. package/lib/client/network.js +12 -9
  23. package/lib/client/page.js +45 -23
  24. package/lib/client/playwright.js +3 -0
  25. package/lib/client/tracing.js +7 -4
  26. package/lib/common/socksProxy.js +2 -2
  27. package/lib/generated/clockSource.js +7 -0
  28. package/lib/generated/injectedScriptSource.js +1 -1
  29. package/lib/generated/recorderSource.js +1 -1
  30. package/lib/generated/utilityScriptSource.js +1 -1
  31. package/lib/protocol/serializers.js +12 -11
  32. package/lib/protocol/validator.js +137 -55
  33. package/lib/server/bidi/bidiBrowser.js +296 -0
  34. package/lib/server/bidi/bidiConnection.js +206 -0
  35. package/lib/server/bidi/bidiExecutionContext.js +162 -0
  36. package/lib/server/bidi/bidiFirefox.js +110 -0
  37. package/lib/server/bidi/bidiInput.js +174 -0
  38. package/lib/server/bidi/bidiNetworkManager.js +304 -0
  39. package/lib/server/bidi/bidiPage.js +456 -0
  40. package/lib/server/bidi/third_party/bidiDeserializer.js +93 -0
  41. package/lib/server/bidi/third_party/bidiKeyboard.js +238 -0
  42. package/lib/server/bidi/third_party/bidiProtocol.js +139 -0
  43. package/lib/server/bidi/third_party/bidiSerializer.js +144 -0
  44. package/lib/server/browser.js +9 -1
  45. package/lib/server/browserContext.js +97 -22
  46. package/lib/server/browserType.js +27 -20
  47. package/lib/server/chromium/chromium.js +30 -15
  48. package/lib/server/chromium/chromiumSwitches.js +6 -3
  49. package/lib/server/chromium/crBrowser.js +11 -17
  50. package/lib/server/chromium/crConnection.js +2 -2
  51. package/lib/server/chromium/crDragDrop.js +28 -29
  52. package/lib/server/chromium/crNetworkManager.js +130 -84
  53. package/lib/server/chromium/crPage.js +34 -79
  54. package/lib/server/chromium/crProtocolHelper.js +3 -1
  55. package/lib/server/chromium/crServiceWorker.js +20 -23
  56. package/lib/server/chromium/videoRecorder.js +1 -1
  57. package/lib/server/clock.js +125 -0
  58. package/lib/server/codegen/csharp.js +299 -0
  59. package/lib/server/codegen/java.js +235 -0
  60. package/lib/server/codegen/javascript.js +223 -0
  61. package/lib/server/codegen/jsonl.js +47 -0
  62. package/lib/server/codegen/language.js +76 -0
  63. package/lib/server/codegen/languages.js +30 -0
  64. package/lib/server/codegen/python.js +265 -0
  65. package/lib/server/codegen/types.js +5 -0
  66. package/lib/server/debugController.js +3 -5
  67. package/lib/server/deviceDescriptors.js +9 -4
  68. package/lib/server/deviceDescriptorsSource.json +239 -119
  69. package/lib/server/dispatchers/androidDispatcher.js +1 -1
  70. package/lib/server/dispatchers/browserContextDispatcher.js +51 -7
  71. package/lib/server/dispatchers/dispatcher.js +36 -40
  72. package/lib/server/dispatchers/frameDispatcher.js +1 -2
  73. package/lib/server/dispatchers/jsHandleDispatcher.js +1 -1
  74. package/lib/server/dispatchers/jsonPipeDispatcher.js +4 -6
  75. package/lib/server/dispatchers/localUtilsDispatcher.js +19 -5
  76. package/lib/server/dispatchers/networkDispatchers.js +2 -2
  77. package/lib/server/dispatchers/pageDispatcher.js +5 -2
  78. package/lib/server/dispatchers/playwrightDispatcher.js +1 -0
  79. package/lib/server/dispatchers/writableStreamDispatcher.js +8 -5
  80. package/lib/server/dom.js +90 -53
  81. package/lib/server/electron/electron.js +21 -4
  82. package/lib/server/fetch.js +74 -25
  83. package/lib/server/fileUploadUtils.js +7 -3
  84. package/lib/server/firefox/ffBrowser.js +36 -25
  85. package/lib/server/firefox/ffConnection.js +2 -2
  86. package/lib/server/firefox/ffNetworkManager.js +6 -4
  87. package/lib/server/firefox/ffPage.js +22 -24
  88. package/lib/server/firefox/firefox.js +25 -6
  89. package/lib/server/frameSelectors.js +2 -2
  90. package/lib/server/frames.js +205 -159
  91. package/lib/server/har/harTracer.js +4 -12
  92. package/lib/server/helper.js +3 -3
  93. package/lib/server/index.js +18 -0
  94. package/lib/server/input.js +18 -8
  95. package/lib/server/instrumentation.js +0 -4
  96. package/lib/server/isomorphic/utilityScriptSerializers.js +19 -5
  97. package/lib/server/javascript.js +3 -2
  98. package/lib/server/launchApp.js +3 -2
  99. package/lib/server/network.js +14 -4
  100. package/lib/server/page.js +75 -46
  101. package/lib/server/playwright.js +5 -2
  102. package/lib/server/recorder/codeGenerator.js +2 -1
  103. package/lib/server/recorder/contextRecorder.js +316 -0
  104. package/lib/server/recorder/csharp.js +2 -1
  105. package/lib/server/recorder/java.js +2 -1
  106. package/lib/server/recorder/javascript.js +2 -1
  107. package/lib/server/recorder/jsonl.js +2 -1
  108. package/lib/server/recorder/language.js +2 -1
  109. package/lib/server/recorder/python.js +2 -1
  110. package/lib/server/recorder/recorderApp.js +14 -5
  111. package/lib/server/recorder/recorderCollection.js +127 -0
  112. package/lib/server/recorder/recorderRunner.js +177 -0
  113. package/lib/server/recorder/recorderUtils.js +23 -0
  114. package/lib/server/recorder/throttledFile.js +46 -0
  115. package/lib/server/recorder/utils.js +2 -1
  116. package/lib/server/recorder.js +42 -418
  117. package/lib/server/registry/index.js +99 -100
  118. package/lib/server/registry/nativeDeps.js +107 -0
  119. package/lib/server/screenshotter.js +6 -12
  120. package/lib/server/socksClientCertificatesInterceptor.js +328 -0
  121. package/lib/server/trace/recorder/snapshotter.js +4 -1
  122. package/lib/server/trace/recorder/tracing.js +27 -96
  123. package/lib/server/trace/viewer/traceViewer.js +54 -67
  124. package/lib/server/transport.js +1 -1
  125. package/lib/server/webkit/webkit.js +5 -5
  126. package/lib/server/webkit/wkBrowser.js +14 -14
  127. package/lib/server/webkit/wkConnection.js +3 -3
  128. package/lib/server/webkit/wkInterceptableRequest.js +8 -4
  129. package/lib/server/webkit/wkPage.js +52 -34
  130. package/lib/server/webkit/wkProvisionalPage.js +36 -1
  131. package/lib/utils/crypto.js +141 -0
  132. package/lib/utils/debugLogger.js +2 -0
  133. package/lib/utils/env.js +4 -2
  134. package/lib/utils/expectUtils.js +33 -0
  135. package/lib/utils/fileUtils.js +140 -1
  136. package/lib/utils/glob.js +2 -1
  137. package/lib/utils/happy-eyeballs.js +29 -2
  138. package/lib/utils/hostPlatform.js +13 -4
  139. package/lib/utils/httpServer.js +54 -13
  140. package/lib/utils/index.js +53 -31
  141. package/lib/utils/isomorphic/cssTokenizer.js +1 -1
  142. package/lib/utils/isomorphic/locatorParser.js +1 -1
  143. package/lib/utils/isomorphic/mimeType.js +29 -0
  144. package/lib/utils/isomorphic/stringUtils.js +28 -1
  145. package/lib/utils/isomorphic/urlMatch.js +120 -0
  146. package/lib/utils/mimeType.js +2 -1
  147. package/lib/utils/network.js +7 -35
  148. package/lib/utils/stackTrace.js +2 -4
  149. package/lib/utils/timeoutRunner.js +11 -76
  150. package/lib/utils/zones.js +23 -60
  151. package/lib/utilsBundle.js +2 -1
  152. package/lib/utilsBundleImpl/index.js +33 -31
  153. package/lib/vite/htmlReport/index.html +12 -12
  154. package/lib/vite/recorder/assets/codeMirrorModule-C-fQ5QZD.js +24 -0
  155. package/lib/vite/recorder/assets/{codicon-zGuYmc9o.ttf → codicon-DCmgc-ay.ttf} +0 -0
  156. package/lib/vite/recorder/assets/index-B-MT5gKo.css +1 -0
  157. package/lib/vite/recorder/assets/index-D-5S5PPN.js +47 -0
  158. package/lib/vite/recorder/index.html +2 -2
  159. package/lib/vite/traceViewer/assets/codeMirrorModule-5yiV-3wl.js +16831 -0
  160. package/lib/vite/traceViewer/assets/codeMirrorModule-B7Z3vq11.js +24 -0
  161. package/lib/vite/traceViewer/assets/codeMirrorModule-C6p3E9Zg.js +24 -0
  162. package/lib/vite/traceViewer/assets/codeMirrorModule-CqYUz5ms.js +24 -0
  163. package/lib/vite/traceViewer/assets/codeMirrorModule-Dx6AXgMV.js +16838 -0
  164. package/lib/vite/traceViewer/assets/codeMirrorModule-T_sdMrbM.js +24 -0
  165. package/lib/vite/traceViewer/assets/codeMirrorModule-V7N6ppkd.js +15585 -0
  166. package/lib/vite/traceViewer/assets/testServerConnection-D-tXL3sj.js +224 -0
  167. package/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +1 -0
  168. package/lib/vite/traceViewer/assets/workbench-Bjkiwcr1.js +19119 -0
  169. package/lib/vite/traceViewer/assets/workbench-C43LWZEX.js +72 -0
  170. package/lib/vite/traceViewer/assets/workbench-C5OQh9VX.js +19119 -0
  171. package/lib/vite/traceViewer/assets/workbench-DrQjKdyE.js +72 -0
  172. package/lib/vite/traceViewer/assets/workbench-caTaZnzx.js +72 -0
  173. package/lib/vite/traceViewer/assets/workbench-u2lRPMOT.js +72 -0
  174. package/lib/vite/traceViewer/assets/wsPort-EUvw-dwH.js +18540 -0
  175. package/lib/vite/traceViewer/assets/xtermModule-CZ7sDYXB.js +6529 -0
  176. package/lib/vite/traceViewer/assets/xtermModule-_6TC5FYT.js +6529 -0
  177. package/lib/vite/traceViewer/codeMirrorModule.Cy8X9Wtw.css +344 -0
  178. package/lib/vite/traceViewer/codeMirrorModule.svF_VrcJ.css +344 -0
  179. package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  180. package/lib/vite/traceViewer/embedded.BQq6Psnz.js +104 -0
  181. package/lib/vite/traceViewer/embedded.BVDVQOzc.js +2 -0
  182. package/lib/vite/traceViewer/embedded.Bn8Ptzv6.js +2 -0
  183. package/lib/vite/traceViewer/embedded.CvhnUgIi.js +2 -0
  184. package/lib/vite/traceViewer/embedded.D27cnKiB.js +104 -0
  185. package/lib/vite/traceViewer/embedded.DPqrDeET.js +2 -0
  186. package/lib/vite/traceViewer/embedded.DjZq4InJ.css +68 -0
  187. package/lib/vite/traceViewer/embedded.html +16 -0
  188. package/lib/vite/traceViewer/embedded.w7WN2u1R.css +1 -0
  189. package/lib/vite/traceViewer/index.5mge2rY_.css +124 -0
  190. package/lib/vite/traceViewer/index.6KJ-JQ0L.js +180 -0
  191. package/lib/vite/traceViewer/index.B8dgQwuN.js +2 -0
  192. package/lib/vite/traceViewer/index.BGj8jY3H.js +2 -0
  193. package/lib/vite/traceViewer/index.C0EgJ4oW.js +195 -0
  194. package/lib/vite/traceViewer/index.CUpI-BFe.js +195 -0
  195. package/lib/vite/traceViewer/{index.-g_5lMbJ.css → index.CrbWWHbf.css} +1 -1
  196. package/lib/vite/traceViewer/index.QanXxRUb.css +131 -0
  197. package/lib/vite/traceViewer/index._cX8k4co.js +2 -0
  198. package/lib/vite/traceViewer/index.html +5 -4
  199. package/lib/vite/traceViewer/index.pMAN88y-.js +2 -0
  200. package/lib/vite/traceViewer/snapshot.html +1 -1
  201. package/lib/vite/traceViewer/sw.bundle.js +3 -4
  202. package/lib/vite/traceViewer/uiMode.D-tg1Oci.js +1730 -0
  203. package/lib/vite/traceViewer/uiMode.D3cNFP6u.css +1 -0
  204. package/lib/vite/traceViewer/uiMode.DKjMBMlc.js +1730 -0
  205. package/lib/vite/traceViewer/uiMode.DVWUEIHq.css +1424 -0
  206. package/lib/vite/traceViewer/uiMode.DVrL7a1K.js +10 -0
  207. package/lib/vite/traceViewer/uiMode.Dg9oJCQU.js +10 -0
  208. package/lib/vite/traceViewer/uiMode.DwZAzstF.js +10 -0
  209. package/lib/vite/traceViewer/uiMode.html +5 -4
  210. package/lib/vite/traceViewer/uiMode.iq7CyYy7.js +1490 -0
  211. package/lib/vite/traceViewer/uiMode.jY2s-9ps.js +10 -0
  212. package/lib/vite/traceViewer/uiMode.xvJHbkzl.css +1324 -0
  213. package/lib/vite/traceViewer/workbench.B3X2QtYa.css +3702 -0
  214. package/lib/vite/traceViewer/workbench.DyTpxWVb.css +1 -0
  215. package/lib/vite/traceViewer/wsPort.p5jUwABW.css +3450 -0
  216. package/lib/vite/traceViewer/xtermModule.4oRVGWQ-.css +209 -0
  217. package/lib/vite/traceViewer/xtermModule.OKEVRlkP.css +209 -0
  218. package/package.json +2 -2
  219. package/types/protocol.d.ts +960 -78
  220. package/types/structs.d.ts +1 -1
  221. package/types/types.d.ts +3083 -2448
  222. package/lib/vite/recorder/assets/codeMirrorModule-W69B4LBB.js +0 -24
  223. package/lib/vite/recorder/assets/index-Ly3PcVUb.js +0 -47
  224. package/lib/vite/recorder/assets/index-ljsTwXtJ.css +0 -1
  225. package/lib/vite/traceViewer/assets/codeMirrorModule-0bpaqixv.js +0 -24
  226. package/lib/vite/traceViewer/assets/codeMirrorModule-wLpsbIhd.js +0 -24
  227. package/lib/vite/traceViewer/assets/wsPort-_JBDEilC.js +0 -69
  228. package/lib/vite/traceViewer/assets/wsPort-f2dAQL4I.js +0 -69
  229. package/lib/vite/traceViewer/index.-_8-eHEE.js +0 -2
  230. package/lib/vite/traceViewer/index.u51inEcm.js +0 -2
  231. package/lib/vite/traceViewer/uiMode.9CwNsWc6.js +0 -10
  232. package/lib/vite/traceViewer/uiMode.Fb0bNA4H.js +0 -10
  233. package/lib/vite/traceViewer/uiMode.pWy0Re7G.css +0 -1
  234. package/lib/vite/traceViewer/wsPort.zR1WIy9-.css +0 -1
  235. /package/lib/vite/recorder/assets/{codeMirrorModule-Hs9-1ZG4.css → codeMirrorModule-ez37Vkbh.css} +0 -0
  236. /package/lib/vite/traceViewer/assets/{xtermModule-Yt6xwiJ_.js → xtermModule-BeNbaIVa.js} +0 -0
  237. /package/lib/vite/traceViewer/{codeMirrorModule.Hs9-1ZG4.css → codeMirrorModule.ez37Vkbh.css} +0 -0
  238. /package/lib/vite/traceViewer/{xtermModule.0lwXJFHT.css → xtermModule.DSXBckUd.css} +0 -0
@@ -0,0 +1,314 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.EventEmitter = void 0;
7
+ var _events = require("events");
8
+ var _utils = require("../utils");
9
+ /**
10
+ * Copyright Joyent, Inc. and other Node contributors.
11
+ * Modifications copyright (c) Microsoft Corporation.
12
+ *
13
+ * Permission is hereby granted, free of charge, to any person obtaining a
14
+ * copy of this software and associated documentation files (the
15
+ * "Software"), to deal in the Software without restriction, including
16
+ * without limitation the rights to use, copy, modify, merge, publish,
17
+ * distribute, sublicense, and/or sell copies of the Software, and to permit
18
+ * persons to whom the Software is furnished to do so, subject to the
19
+ * following conditions:
20
+ *
21
+ * The above copyright notice and this permission notice shall be included
22
+ * in all copies or substantial portions of the Software.
23
+ *
24
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
25
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
27
+ * NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
28
+ * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
29
+ * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
30
+ * USE OR OTHER DEALINGS IN THE SOFTWARE.
31
+ */
32
+
33
+ class EventEmitter {
34
+ constructor() {
35
+ this._events = undefined;
36
+ this._eventsCount = 0;
37
+ this._maxListeners = undefined;
38
+ this._pendingHandlers = new Map();
39
+ this._rejectionHandler = void 0;
40
+ if (this._events === undefined || this._events === Object.getPrototypeOf(this)._events) {
41
+ this._events = Object.create(null);
42
+ this._eventsCount = 0;
43
+ }
44
+ this._maxListeners = this._maxListeners || undefined;
45
+ this.on = this.addListener;
46
+ this.off = this.removeListener;
47
+ }
48
+ setMaxListeners(n) {
49
+ if (typeof n !== 'number' || n < 0 || Number.isNaN(n)) throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received ' + n + '.');
50
+ this._maxListeners = n;
51
+ return this;
52
+ }
53
+ getMaxListeners() {
54
+ return this._maxListeners === undefined ? _events.EventEmitter.defaultMaxListeners : this._maxListeners;
55
+ }
56
+ emit(type, ...args) {
57
+ const events = this._events;
58
+ if (events === undefined) return false;
59
+ const handler = events === null || events === void 0 ? void 0 : events[type];
60
+ if (handler === undefined) return false;
61
+ if (typeof handler === 'function') {
62
+ this._callHandler(type, handler, args);
63
+ } else {
64
+ const len = handler.length;
65
+ const listeners = handler.slice();
66
+ for (let i = 0; i < len; ++i) this._callHandler(type, listeners[i], args);
67
+ }
68
+ return true;
69
+ }
70
+ _callHandler(type, handler, args) {
71
+ const promise = Reflect.apply(handler, this, args);
72
+ if (!(promise instanceof Promise)) return;
73
+ let set = this._pendingHandlers.get(type);
74
+ if (!set) {
75
+ set = new Set();
76
+ this._pendingHandlers.set(type, set);
77
+ }
78
+ set.add(promise);
79
+ promise.catch(e => {
80
+ if (this._rejectionHandler) this._rejectionHandler(e);else throw e;
81
+ }).finally(() => set.delete(promise));
82
+ }
83
+ addListener(type, listener) {
84
+ return this._addListener(type, listener, false);
85
+ }
86
+ on(type, listener) {
87
+ return this._addListener(type, listener, false);
88
+ }
89
+ _addListener(type, listener, prepend) {
90
+ checkListener(listener);
91
+ let events = this._events;
92
+ let existing;
93
+ if (events === undefined) {
94
+ events = this._events = Object.create(null);
95
+ this._eventsCount = 0;
96
+ } else {
97
+ // To avoid recursion in the case that type === "newListener"! Before
98
+ // adding it to the listeners, first emit "newListener".
99
+ if (events.newListener !== undefined) {
100
+ this.emit('newListener', type, unwrapListener(listener));
101
+
102
+ // Re-assign `events` because a newListener handler could have caused the
103
+ // this._events to be assigned to a new object
104
+ events = this._events;
105
+ }
106
+ existing = events[type];
107
+ }
108
+ if (existing === undefined) {
109
+ // Optimize the case of one listener. Don't need the extra array object.
110
+ existing = events[type] = listener;
111
+ ++this._eventsCount;
112
+ } else {
113
+ if (typeof existing === 'function') {
114
+ // Adding the second element, need to change to array.
115
+ existing = events[type] = prepend ? [listener, existing] : [existing, listener];
116
+ // If we've already got an array, just append.
117
+ } else if (prepend) {
118
+ existing.unshift(listener);
119
+ } else {
120
+ existing.push(listener);
121
+ }
122
+
123
+ // Check for listener leak
124
+ const m = this.getMaxListeners();
125
+ if (m > 0 && existing.length > m && !existing.warned) {
126
+ existing.warned = true;
127
+ // No error code for this since it is a Warning
128
+ const w = new Error('Possible EventEmitter memory leak detected. ' + existing.length + ' ' + String(type) + ' listeners ' + 'added. Use emitter.setMaxListeners() to ' + 'increase limit');
129
+ w.name = 'MaxListenersExceededWarning';
130
+ w.emitter = this;
131
+ w.type = type;
132
+ w.count = existing.length;
133
+ if (!(0, _utils.isUnderTest)()) {
134
+ // eslint-disable-next-line no-console
135
+ console.warn(w);
136
+ }
137
+ }
138
+ }
139
+ return this;
140
+ }
141
+ prependListener(type, listener) {
142
+ return this._addListener(type, listener, true);
143
+ }
144
+ once(type, listener) {
145
+ checkListener(listener);
146
+ this.on(type, new OnceWrapper(this, type, listener).wrapperFunction);
147
+ return this;
148
+ }
149
+ prependOnceListener(type, listener) {
150
+ checkListener(listener);
151
+ this.prependListener(type, new OnceWrapper(this, type, listener).wrapperFunction);
152
+ return this;
153
+ }
154
+ removeListener(type, listener) {
155
+ checkListener(listener);
156
+ const events = this._events;
157
+ if (events === undefined) return this;
158
+ const list = events[type];
159
+ if (list === undefined) return this;
160
+ if (list === listener || list.listener === listener) {
161
+ if (--this._eventsCount === 0) {
162
+ this._events = Object.create(null);
163
+ } else {
164
+ var _listener;
165
+ delete events[type];
166
+ if (events.removeListener) this.emit('removeListener', type, (_listener = list.listener) !== null && _listener !== void 0 ? _listener : listener);
167
+ }
168
+ } else if (typeof list !== 'function') {
169
+ let position = -1;
170
+ let originalListener;
171
+ for (let i = list.length - 1; i >= 0; i--) {
172
+ if (list[i] === listener || wrappedListener(list[i]) === listener) {
173
+ originalListener = wrappedListener(list[i]);
174
+ position = i;
175
+ break;
176
+ }
177
+ }
178
+ if (position < 0) return this;
179
+ if (position === 0) list.shift();else list.splice(position, 1);
180
+ if (list.length === 1) events[type] = list[0];
181
+ if (events.removeListener !== undefined) this.emit('removeListener', type, originalListener || listener);
182
+ }
183
+ return this;
184
+ }
185
+ off(type, listener) {
186
+ return this.removeListener(type, listener);
187
+ }
188
+ removeAllListeners(type, options) {
189
+ this._removeAllListeners(type);
190
+ if (!options) return this;
191
+ if (options.behavior === 'wait') {
192
+ const errors = [];
193
+ this._rejectionHandler = error => errors.push(error);
194
+ // eslint-disable-next-line internal-playwright/await-promise-in-class-returns
195
+ return this._waitFor(type).then(() => {
196
+ if (errors.length) throw errors[0];
197
+ });
198
+ }
199
+ if (options.behavior === 'ignoreErrors') this._rejectionHandler = () => {};
200
+
201
+ // eslint-disable-next-line internal-playwright/await-promise-in-class-returns
202
+ return Promise.resolve();
203
+ }
204
+ _removeAllListeners(type) {
205
+ const events = this._events;
206
+ if (!events) return;
207
+
208
+ // not listening for removeListener, no need to emit
209
+ if (!events.removeListener) {
210
+ if (type === undefined) {
211
+ this._events = Object.create(null);
212
+ this._eventsCount = 0;
213
+ } else if (events[type] !== undefined) {
214
+ if (--this._eventsCount === 0) this._events = Object.create(null);else delete events[type];
215
+ }
216
+ return;
217
+ }
218
+
219
+ // emit removeListener for all listeners on all events
220
+ if (type === undefined) {
221
+ const keys = Object.keys(events);
222
+ let key;
223
+ for (let i = 0; i < keys.length; ++i) {
224
+ key = keys[i];
225
+ if (key === 'removeListener') continue;
226
+ this._removeAllListeners(key);
227
+ }
228
+ this._removeAllListeners('removeListener');
229
+ this._events = Object.create(null);
230
+ this._eventsCount = 0;
231
+ return;
232
+ }
233
+ const listeners = events[type];
234
+ if (typeof listeners === 'function') {
235
+ this.removeListener(type, listeners);
236
+ } else if (listeners !== undefined) {
237
+ // LIFO order
238
+ for (let i = listeners.length - 1; i >= 0; i--) this.removeListener(type, listeners[i]);
239
+ }
240
+ }
241
+ listeners(type) {
242
+ return this._listeners(this, type, true);
243
+ }
244
+ rawListeners(type) {
245
+ return this._listeners(this, type, false);
246
+ }
247
+ listenerCount(type) {
248
+ const events = this._events;
249
+ if (events !== undefined) {
250
+ const listener = events[type];
251
+ if (typeof listener === 'function') return 1;
252
+ if (listener !== undefined) return listener.length;
253
+ }
254
+ return 0;
255
+ }
256
+ eventNames() {
257
+ return this._eventsCount > 0 && this._events ? Reflect.ownKeys(this._events) : [];
258
+ }
259
+ async _waitFor(type) {
260
+ let promises = [];
261
+ if (type) {
262
+ promises = [...(this._pendingHandlers.get(type) || [])];
263
+ } else {
264
+ promises = [];
265
+ for (const [, pending] of this._pendingHandlers) promises.push(...pending);
266
+ }
267
+ await Promise.all(promises);
268
+ }
269
+ _listeners(target, type, unwrap) {
270
+ const events = target._events;
271
+ if (events === undefined) return [];
272
+ const listener = events[type];
273
+ if (listener === undefined) return [];
274
+ if (typeof listener === 'function') return unwrap ? [unwrapListener(listener)] : [listener];
275
+ return unwrap ? unwrapListeners(listener) : listener.slice();
276
+ }
277
+ }
278
+ exports.EventEmitter = EventEmitter;
279
+ function checkListener(listener) {
280
+ if (typeof listener !== 'function') throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener);
281
+ }
282
+ class OnceWrapper {
283
+ constructor(eventEmitter, eventType, listener) {
284
+ this._fired = false;
285
+ this.wrapperFunction = void 0;
286
+ this._listener = void 0;
287
+ this._eventEmitter = void 0;
288
+ this._eventType = void 0;
289
+ this._eventEmitter = eventEmitter;
290
+ this._eventType = eventType;
291
+ this._listener = listener;
292
+ this.wrapperFunction = this._handle.bind(this);
293
+ this.wrapperFunction.listener = listener;
294
+ }
295
+ _handle(...args) {
296
+ if (this._fired) return;
297
+ this._fired = true;
298
+ this._eventEmitter.removeListener(this._eventType, this.wrapperFunction);
299
+ return this._listener.apply(this._eventEmitter, args);
300
+ }
301
+ }
302
+ function unwrapListener(l) {
303
+ var _wrappedListener;
304
+ return (_wrappedListener = wrappedListener(l)) !== null && _wrappedListener !== void 0 ? _wrappedListener : l;
305
+ }
306
+ function unwrapListeners(arr) {
307
+ return arr.map(l => {
308
+ var _wrappedListener2;
309
+ return (_wrappedListener2 = wrappedListener(l)) !== null && _wrappedListener2 !== void 0 ? _wrappedListener2 : l;
310
+ });
311
+ }
312
+ function wrappedListener(l) {
313
+ return l.listener;
314
+ }
@@ -13,6 +13,7 @@ var _channelOwner = require("./channelOwner");
13
13
  var _network = require("./network");
14
14
  var _tracing = require("./tracing");
15
15
  var _errors = require("./errors");
16
+ var _browserContext = require("./browserContext");
16
17
  var _fetch = require("../checkly/fetch");
17
18
  let _Symbol$asyncDispose, _Symbol$asyncDispose2, _util$inspect$custom;
18
19
  /**
@@ -54,12 +55,13 @@ class APIRequest {
54
55
  ...options,
55
56
  extraHTTPHeaders: options.extraHTTPHeaders ? (0, _utils.headersObjectToArray)(options.extraHTTPHeaders) : undefined,
56
57
  storageState,
57
- tracesDir
58
+ tracesDir,
59
+ clientCertificates: await (0, _browserContext.toClientCertificatesProtocol)(options.clientCertificates)
58
60
  })).request);
59
61
  this._contexts.add(context);
60
62
  context._request = this;
61
63
  context._tracing._tracesDir = tracesDir;
62
- await context._instrumentation.onDidCreateRequestContext(context);
64
+ await context._instrumentation.runAfterCreateRequestContext(context);
63
65
  return context;
64
66
  }
65
67
  }
@@ -73,15 +75,23 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
73
75
  super(parent, type, guid, initializer);
74
76
  this._request = void 0;
75
77
  this._tracing = void 0;
78
+ this._closeReason = void 0;
76
79
  this._tracing = _tracing.Tracing.from(initializer.tracing);
77
80
  }
78
81
  async [_Symbol$asyncDispose]() {
79
82
  await this.dispose();
80
83
  }
81
- async dispose() {
84
+ async dispose(options = {}) {
82
85
  var _this$_request;
83
- await this._instrumentation.onWillCloseRequestContext(this);
84
- await this._channel.dispose();
86
+ this._closeReason = options.reason;
87
+ await this._instrumentation.runBeforeCloseRequestContext(this);
88
+ try {
89
+ await this._channel.dispose(options);
90
+ } catch (e) {
91
+ if ((0, _errors.isTargetClosedError)(e)) return;
92
+ throw e;
93
+ }
94
+ this._tracing._resetStackCounter();
85
95
  (_this$_request = this._request) === null || _this$_request === void 0 || _this$_request._contexts.delete(this);
86
96
  }
87
97
  async delete(url, options) {
@@ -138,13 +148,14 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
138
148
  this.writeApiCallToDisk(options);
139
149
  return await this._wrapApiCall(async () => {
140
150
  var _options$request, _options$request2, _options$request3;
151
+ if (this._closeReason) throw new _errors.TargetClosedError(this._closeReason);
141
152
  (0, _utils.assert)(options.request || typeof options.url === 'string', 'First argument must be either URL string or Request');
142
153
  (0, _utils.assert)((options.data === undefined ? 0 : 1) + (options.form === undefined ? 0 : 1) + (options.multipart === undefined ? 0 : 1) <= 1, `Only one of 'data', 'form' or 'multipart' can be specified`);
143
- (0, _utils.assert)(options.maxRedirects === undefined || options.maxRedirects >= 0, `'maxRedirects' should be greater than or equal to '0'`);
154
+ (0, _utils.assert)(options.maxRedirects === undefined || options.maxRedirects >= 0, `'maxRedirects' must be greater than or equal to '0'`);
155
+ (0, _utils.assert)(options.maxRetries === undefined || options.maxRetries >= 0, `'maxRetries' must be greater than or equal to '0'`);
144
156
  const url = options.url !== undefined ? options.url : options.request.url();
145
- const params = objectToArray(options.params);
157
+ const params = mapParamsToArray(options.params);
146
158
  const method = options.method || ((_options$request = options.request) === null || _options$request === void 0 ? void 0 : _options$request.method());
147
- const maxRedirects = options.maxRedirects;
148
159
  // Cannot call allHeaders() here as the request may be paused inside route handler.
149
160
  const headersObj = options.headers || ((_options$request2 = options.request) === null || _options$request2 === void 0 ? void 0 : _options$request2.headers());
150
161
  const headers = headersObj ? (0, _utils.headersObjectToArray)(headersObj) : undefined;
@@ -166,26 +177,29 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
166
177
  formData = objectToArray(options.form);
167
178
  } else if (options.multipart) {
168
179
  multipartData = [];
169
- // Convert file-like values to ServerFilePayload structs.
170
- for (const [name, value] of Object.entries(options.multipart)) {
171
- if (isFilePayload(value)) {
172
- const payload = value;
173
- if (!Buffer.isBuffer(payload.buffer)) throw new Error(`Unexpected buffer type of 'data.${name}'`);
174
- multipartData.push({
175
- name,
176
- file: filePayloadToJson(payload)
177
- });
178
- } else if (value instanceof _fs.default.ReadStream) {
179
- multipartData.push({
180
- name,
181
- file: await readStreamToJson(value)
182
- });
183
- } else {
184
- multipartData.push({
185
- name,
186
- value: String(value)
187
- });
180
+ if (globalThis.FormData && options.multipart instanceof FormData) {
181
+ const form = options.multipart;
182
+ for (const [name, value] of form.entries()) {
183
+ if ((0, _utils.isString)(value)) {
184
+ multipartData.push({
185
+ name,
186
+ value
187
+ });
188
+ } else {
189
+ const file = {
190
+ name: value.name,
191
+ mimeType: value.type,
192
+ buffer: Buffer.from(await value.arrayBuffer())
193
+ };
194
+ multipartData.push({
195
+ name,
196
+ file
197
+ });
198
+ }
188
199
  }
200
+ } else {
201
+ // Convert file-like values to ServerFilePayload structs.
202
+ for (const [name, value] of Object.entries(options.multipart)) multipartData.push(await toFormField(name, value));
189
203
  }
190
204
  }
191
205
  if (postDataBuffer === undefined && jsonData === undefined && formData === undefined && multipartData === undefined) postDataBuffer = ((_options$request3 = options.request) === null || _options$request3 === void 0 ? void 0 : _options$request3.postDataBuffer()) || undefined;
@@ -204,7 +218,8 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
204
218
  timeout: options.timeout,
205
219
  failOnStatusCode: options.failOnStatusCode,
206
220
  ignoreHTTPSErrors: options.ignoreHTTPSErrors,
207
- maxRedirects: maxRedirects,
221
+ maxRedirects: options.maxRedirects,
222
+ maxRetries: options.maxRetries,
208
223
  tokenizedURL: options.tokenizedURL,
209
224
  ...fixtures,
210
225
  ...(0, _fetch.getClientCertificates)(options)
@@ -222,6 +237,26 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
222
237
  }
223
238
  }
224
239
  exports.APIRequestContext = APIRequestContext;
240
+ async function toFormField(name, value) {
241
+ if (isFilePayload(value)) {
242
+ const payload = value;
243
+ if (!Buffer.isBuffer(payload.buffer)) throw new Error(`Unexpected buffer type of 'data.${name}'`);
244
+ return {
245
+ name,
246
+ file: filePayloadToJson(payload)
247
+ };
248
+ } else if (value instanceof _fs.default.ReadStream) {
249
+ return {
250
+ name,
251
+ file: await readStreamToJson(value)
252
+ };
253
+ } else {
254
+ return {
255
+ name,
256
+ value: String(value)
257
+ };
258
+ }
259
+ }
225
260
  function isJsonParsable(value) {
226
261
  if (typeof value !== 'string') return false;
227
262
  try {
@@ -353,6 +388,24 @@ function objectToArray(map) {
353
388
  });
354
389
  return result;
355
390
  }
391
+ function queryStringToArray(queryString) {
392
+ const searchParams = new URLSearchParams(queryString);
393
+ return searchParamsToArray(searchParams);
394
+ }
395
+ function searchParamsToArray(searchParams) {
396
+ if (searchParams.size === 0) return undefined;
397
+ const result = [];
398
+ for (const [name, value] of searchParams.entries()) result.push({
399
+ name,
400
+ value
401
+ });
402
+ return result;
403
+ }
404
+ function mapParamsToArray(params) {
405
+ if (params instanceof URLSearchParams) return searchParamsToArray(params);
406
+ if (typeof params === 'string') return queryStringToArray(params);
407
+ return objectToArray(params);
408
+ }
356
409
  function isFilePayload(value) {
357
410
  return typeof value === 'object' && value['name'] && value['mimeType'] && value['buffer'];
358
411
  }
@@ -17,7 +17,6 @@ var _events = require("events");
17
17
  var _waiter = require("./waiter");
18
18
  var _events2 = require("./events");
19
19
  var _types = require("./types");
20
- var _network2 = require("../utils/network");
21
20
  var _clientHelper = require("./clientHelper");
22
21
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
23
22
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
@@ -111,7 +110,7 @@ class Frame extends _channelOwner.ChannelOwner {
111
110
  // Any failed navigation results in a rejection.
112
111
  if (event.error) return true;
113
112
  waiter.log(` navigated to "${event.url}"`);
114
- return (0, _network2.urlMatches)((_this$_page = this._page) === null || _this$_page === void 0 ? void 0 : _this$_page.context()._options.baseURL, event.url, options.url);
113
+ return (0, _utils.urlMatches)((_this$_page = this._page) === null || _this$_page === void 0 ? void 0 : _this$_page.context()._options.baseURL, event.url, options.url);
115
114
  });
116
115
  if (navigatedEvent.error) {
117
116
  const e = new Error(navigatedEvent.error);
@@ -147,7 +146,7 @@ class Frame extends _channelOwner.ChannelOwner {
147
146
  }
148
147
  async waitForURL(url, options = {}) {
149
148
  var _this$_page2;
150
- if ((0, _network2.urlMatches)((_this$_page2 = this._page) === null || _this$_page2 === void 0 ? void 0 : _this$_page2.context()._options.baseURL, this.url(), url)) return await this.waitForLoadState(options.waitUntil, options);
149
+ if ((0, _utils.urlMatches)((_this$_page2 = this._page) === null || _this$_page2 === void 0 ? void 0 : _this$_page2.context()._options.baseURL, this.url(), url)) return await this.waitForLoadState(options.waitUntil, options);
151
150
  await this.waitForNavigation({
152
151
  url,
153
152
  ...options
@@ -179,7 +178,6 @@ class Frame extends _channelOwner.ChannelOwner {
179
178
  const result = await this._channel.evaluateExpression({
180
179
  expression: String(pageFunction),
181
180
  isFunction: typeof pageFunction === 'function',
182
- exposeUtilityScript: true,
183
181
  arg: (0, _jsHandle.serializeArgument)(arg)
184
182
  });
185
183
  return (0, _jsHandle.parseResult)(result.value);
@@ -9,6 +9,7 @@ exports.parseResult = parseResult;
9
9
  exports.serializeArgument = serializeArgument;
10
10
  var _channelOwner = require("./channelOwner");
11
11
  var _serializers = require("../protocol/serializers");
12
+ var _errors = require("./errors");
12
13
  let _Symbol$asyncDispose;
13
14
  /**
14
15
  * Copyright (c) Microsoft Corporation.
@@ -78,7 +79,12 @@ class JSHandle extends _channelOwner.ChannelOwner {
78
79
  await this.dispose();
79
80
  }
80
81
  async dispose() {
81
- return await this._channel.dispose();
82
+ try {
83
+ await this._channel.dispose();
84
+ } catch (e) {
85
+ if ((0, _errors.isTargetClosedError)(e)) return;
86
+ throw e;
87
+ }
82
88
  }
83
89
  async _objectCount() {
84
90
  return await this._wrapApiCall(async () => {
@@ -71,6 +71,9 @@ class Locator {
71
71
  }
72
72
  });
73
73
  }
74
+ _equals(locator) {
75
+ return this._frame === locator._frame && this._selector === locator._selector;
76
+ }
74
77
  page() {
75
78
  return this._frame.page();
76
79
  }
@@ -174,6 +177,9 @@ class Locator {
174
177
  async elementHandles() {
175
178
  return await this._frame.$$(this._selector);
176
179
  }
180
+ contentFrame() {
181
+ return new FrameLocator(this._frame, this._selector);
182
+ }
177
183
  first() {
178
184
  return new Locator(this._frame, this._selector + ' >> nth=0');
179
185
  }
@@ -409,6 +415,9 @@ class FrameLocator {
409
415
  getByRole(role, options = {}) {
410
416
  return this.locator((0, _locatorUtils.getByRoleSelector)(role, options));
411
417
  }
418
+ owner() {
419
+ return new Locator(this._frame, this._frameSelector);
420
+ }
412
421
  frameLocator(selector) {
413
422
  return new FrameLocator(this._frame, this._frameSelector + ' >> internal:control=enter-frame >> ' + selector);
414
423
  }
@@ -15,9 +15,8 @@ var _utils = require("../utils");
15
15
  var _manualPromise = require("../utils/manualPromise");
16
16
  var _events = require("./events");
17
17
  var _waiter = require("./waiter");
18
- var _network = require("../utils/network");
19
- var _multimap = require("../utils/multimap");
20
18
  var _fetch = require("./fetch");
19
+ var _errors = require("./errors");
21
20
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
22
21
  /**
23
22
  * Copyright (c) Microsoft Corporation.
@@ -54,7 +53,6 @@ class Request extends _channelOwner.ChannelOwner {
54
53
  this._redirectedFrom = Request.fromNullable(initializer.redirectedFrom);
55
54
  if (this._redirectedFrom) this._redirectedFrom._redirectedTo = this;
56
55
  this._provisionalHeaders = new RawHeaders(initializer.headers);
57
- this._fallbackOverrides.postDataBuffer = initializer.postData;
58
56
  this._timing = {
59
57
  startTime: 0,
60
58
  domainLookupStart: -1,
@@ -77,17 +75,17 @@ class Request extends _channelOwner.ChannelOwner {
77
75
  return this._fallbackOverrides.method || this._initializer.method;
78
76
  }
79
77
  postData() {
80
- var _this$_fallbackOverri;
81
- return ((_this$_fallbackOverri = this._fallbackOverrides.postDataBuffer) === null || _this$_fallbackOverri === void 0 ? void 0 : _this$_fallbackOverri.toString('utf-8')) || null;
78
+ var _ref;
79
+ return ((_ref = this._fallbackOverrides.postDataBuffer || this._initializer.postData) === null || _ref === void 0 ? void 0 : _ref.toString('utf-8')) || null;
82
80
  }
83
81
  postDataBuffer() {
84
- return this._fallbackOverrides.postDataBuffer || null;
82
+ return this._fallbackOverrides.postDataBuffer || this._initializer.postData || null;
85
83
  }
86
84
  postDataJSON() {
87
85
  const postData = this.postData();
88
86
  if (!postData) return null;
89
87
  const contentType = this.headers()['content-type'];
90
- if (contentType === 'application/x-www-form-urlencoded') {
88
+ if (contentType !== null && contentType !== void 0 && contentType.includes('application/x-www-form-urlencoded')) {
91
89
  const entries = {};
92
90
  const parsed = new _url.URLSearchParams(postData);
93
91
  for (const [k, v] of parsed.entries()) entries[k] = v;
@@ -520,7 +518,7 @@ class RouteHandler {
520
518
  return patterns;
521
519
  }
522
520
  matches(requestURL) {
523
- return (0, _network.urlMatches)(this._baseURL, requestURL, this.url);
521
+ return (0, _utils.urlMatches)(this._baseURL, requestURL, this.url);
524
522
  }
525
523
  async handle(route) {
526
524
  const handlerInvocation = {
@@ -533,6 +531,11 @@ class RouteHandler {
533
531
  } catch (e) {
534
532
  // If the handler was stopped (without waiting for completion), we ignore all exceptions.
535
533
  if (this._ignoreException) return false;
534
+ if ((0, _errors.isTargetClosedError)(e)) {
535
+ // We are failing in the handler because the target close closed.
536
+ // Give user a hint!
537
+ (0, _utils.rewriteErrorMessage)(e, `"${e.message}" while running route callback.\nConsider awaiting \`await page.unrouteAll({ behavior: 'ignoreErrors' })\`\nbefore the end of the test to ignore remaining routes in flight.`);
538
+ }
536
539
  throw e;
537
540
  } finally {
538
541
  handlerInvocation.complete.resolve();
@@ -577,7 +580,7 @@ class RawHeaders {
577
580
  }
578
581
  constructor(headers) {
579
582
  this._headersArray = void 0;
580
- this._headersMap = new _multimap.MultiMap();
583
+ this._headersMap = new _utils.MultiMap();
581
584
  this._headersArray = headers;
582
585
  for (const header of headers) this._headersMap.set(header.name.toLowerCase(), header.value);
583
586
  }