patchright-bun-core 1.58.0 → 1.59.0

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 (475) hide show
  1. package/README.md +2 -2
  2. package/ThirdPartyNotices.txt +3551 -4075
  3. package/bin/install_media_pack.ps1 +5 -5
  4. package/bin/install_webkit_wsl.ps1 +32 -32
  5. package/bin/reinstall_chrome_beta_linux.sh +42 -42
  6. package/bin/reinstall_chrome_beta_mac.sh +13 -13
  7. package/bin/reinstall_chrome_beta_win.ps1 +24 -24
  8. package/bin/reinstall_chrome_stable_linux.sh +42 -42
  9. package/bin/reinstall_chrome_stable_mac.sh +12 -12
  10. package/bin/reinstall_chrome_stable_win.ps1 +24 -24
  11. package/bin/reinstall_msedge_beta_linux.sh +48 -48
  12. package/bin/reinstall_msedge_beta_mac.sh +11 -11
  13. package/bin/reinstall_msedge_beta_win.ps1 +23 -23
  14. package/bin/reinstall_msedge_dev_linux.sh +48 -48
  15. package/bin/reinstall_msedge_dev_mac.sh +11 -11
  16. package/bin/reinstall_msedge_dev_win.ps1 +23 -23
  17. package/bin/reinstall_msedge_stable_linux.sh +48 -48
  18. package/bin/reinstall_msedge_stable_mac.sh +11 -11
  19. package/bin/reinstall_msedge_stable_win.ps1 +23 -23
  20. package/browsers.json +81 -79
  21. package/cli.js +18 -18
  22. package/index.d.ts +17 -17
  23. package/index.js +32 -32
  24. package/index.mjs +28 -28
  25. package/lib/androidServerImpl.js +65 -65
  26. package/lib/bootstrap.js +77 -0
  27. package/lib/browserServerImpl.js +120 -120
  28. package/lib/cli/browserActions.js +308 -0
  29. package/lib/cli/driver.js +98 -97
  30. package/lib/cli/installActions.js +171 -0
  31. package/lib/cli/program.js +225 -589
  32. package/lib/cli/programWithTestStub.js +74 -74
  33. package/lib/client/android.js +361 -361
  34. package/lib/client/api.js +137 -137
  35. package/lib/client/artifact.js +79 -79
  36. package/lib/client/browser.js +169 -161
  37. package/lib/client/browserContext.js +563 -582
  38. package/lib/client/browserType.js +153 -185
  39. package/lib/client/cdpSession.js +55 -51
  40. package/lib/client/channelOwner.js +194 -194
  41. package/lib/client/clientHelper.js +64 -64
  42. package/lib/client/clientInstrumentation.js +55 -55
  43. package/lib/client/clientStackTrace.js +69 -69
  44. package/lib/client/clock.js +68 -68
  45. package/lib/client/{webSocket.js → connect.js} +143 -93
  46. package/lib/client/connection.js +322 -318
  47. package/lib/client/consoleMessage.js +61 -58
  48. package/lib/client/coverage.js +44 -44
  49. package/lib/client/debugger.js +57 -0
  50. package/lib/client/dialog.js +63 -56
  51. package/lib/client/disposable.js +76 -0
  52. package/lib/client/download.js +62 -62
  53. package/lib/client/electron.js +139 -138
  54. package/lib/client/elementHandle.js +281 -284
  55. package/lib/client/errors.js +77 -77
  56. package/lib/client/eventEmitter.js +314 -314
  57. package/lib/client/events.js +103 -103
  58. package/lib/client/fetch.js +367 -368
  59. package/lib/client/fileChooser.js +46 -46
  60. package/lib/client/fileUtils.js +34 -34
  61. package/lib/client/frame.js +404 -409
  62. package/lib/client/harRouter.js +99 -87
  63. package/lib/client/input.js +84 -84
  64. package/lib/client/jsHandle.js +105 -109
  65. package/lib/client/jsonPipe.js +39 -39
  66. package/lib/client/localUtils.js +60 -60
  67. package/lib/client/locator.js +367 -369
  68. package/lib/client/network.js +750 -747
  69. package/lib/client/page.js +731 -745
  70. package/lib/client/platform.js +74 -77
  71. package/lib/client/playwright.js +71 -71
  72. package/lib/client/screencast.js +88 -0
  73. package/lib/client/selectors.js +57 -55
  74. package/lib/client/stream.js +39 -39
  75. package/lib/client/timeoutSettings.js +79 -79
  76. package/lib/client/tracing.js +126 -119
  77. package/lib/client/types.js +28 -28
  78. package/lib/client/video.js +52 -59
  79. package/lib/client/waiter.js +142 -142
  80. package/lib/client/webError.js +39 -39
  81. package/lib/client/worker.js +85 -85
  82. package/lib/client/writableStream.js +39 -39
  83. package/lib/generated/bindingsControllerSource.js +28 -28
  84. package/lib/generated/clockSource.js +28 -28
  85. package/lib/generated/injectedScriptSource.js +28 -28
  86. package/lib/generated/pollingRecorderSource.js +28 -28
  87. package/lib/generated/storageScriptSource.js +28 -28
  88. package/lib/generated/utilityScriptSource.js +28 -28
  89. package/lib/generated/webSocketMockSource.js +336 -336
  90. package/lib/inProcessFactory.js +60 -60
  91. package/lib/inprocess.js +3 -3
  92. package/lib/mcpBundle.js +78 -84
  93. package/lib/mcpBundleImpl.js +91 -0
  94. package/lib/outofprocess.js +76 -76
  95. package/lib/protocol/serializers.js +197 -197
  96. package/lib/protocol/validator.js +3067 -2969
  97. package/lib/protocol/validatorPrimitives.js +193 -193
  98. package/lib/remote/playwrightConnection.js +131 -129
  99. package/lib/remote/playwrightPipeServer.js +100 -0
  100. package/lib/remote/playwrightServer.js +339 -334
  101. package/lib/remote/playwrightWebSocketServer.js +73 -0
  102. package/lib/remote/serverTransport.js +96 -0
  103. package/lib/server/android/android.js +465 -465
  104. package/lib/server/android/backendAdb.js +177 -177
  105. package/lib/server/artifact.js +127 -127
  106. package/lib/server/bidi/bidiBrowser.js +571 -549
  107. package/lib/server/bidi/bidiChromium.js +162 -148
  108. package/lib/server/bidi/bidiConnection.js +213 -213
  109. package/lib/server/bidi/bidiDeserializer.js +116 -116
  110. package/lib/server/bidi/bidiExecutionContext.js +267 -267
  111. package/lib/server/bidi/bidiFirefox.js +128 -128
  112. package/lib/server/bidi/bidiInput.js +146 -146
  113. package/lib/server/bidi/bidiNetworkManager.js +411 -383
  114. package/lib/server/bidi/bidiOverCdp.js +102 -102
  115. package/lib/server/bidi/bidiPage.js +599 -583
  116. package/lib/server/bidi/bidiPdf.js +106 -106
  117. package/lib/server/bidi/third_party/bidiCommands.d.js +22 -22
  118. package/lib/server/bidi/third_party/bidiKeyboard.js +256 -256
  119. package/lib/server/bidi/third_party/bidiProtocol.js +24 -24
  120. package/lib/server/bidi/third_party/bidiProtocolCore.js +180 -180
  121. package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -42
  122. package/lib/server/bidi/third_party/bidiSerializer.js +148 -148
  123. package/lib/server/bidi/third_party/firefoxPrefs.js +261 -259
  124. package/lib/server/browser.js +212 -149
  125. package/lib/server/browserContext.js +741 -702
  126. package/lib/server/browserType.js +338 -336
  127. package/lib/server/callLog.js +82 -82
  128. package/lib/server/chromium/chromium.js +399 -395
  129. package/lib/server/chromium/chromiumSwitches.js +104 -104
  130. package/lib/server/chromium/crBrowser.js +528 -511
  131. package/lib/server/chromium/crConnection.js +197 -197
  132. package/lib/server/chromium/crCoverage.js +235 -235
  133. package/lib/server/chromium/crDevTools.js +111 -111
  134. package/lib/server/chromium/crDragDrop.js +131 -131
  135. package/lib/server/chromium/crExecutionContext.js +146 -146
  136. package/lib/server/chromium/crInput.js +187 -187
  137. package/lib/server/chromium/crNetworkManager.js +707 -707
  138. package/lib/server/chromium/crPage.js +963 -1001
  139. package/lib/server/chromium/crPdf.js +121 -121
  140. package/lib/server/chromium/crProtocolHelper.js +145 -145
  141. package/lib/server/chromium/crServiceWorker.js +137 -136
  142. package/lib/server/chromium/defaultFontFamilies.js +162 -162
  143. package/lib/server/chromium/protocol.d.js +16 -16
  144. package/lib/server/clock.js +149 -149
  145. package/lib/server/codegen/csharp.js +327 -327
  146. package/lib/server/codegen/java.js +274 -274
  147. package/lib/server/codegen/javascript.js +247 -247
  148. package/lib/server/codegen/jsonl.js +52 -52
  149. package/lib/server/codegen/language.js +132 -132
  150. package/lib/server/codegen/languages.js +68 -68
  151. package/lib/server/codegen/python.js +279 -279
  152. package/lib/server/codegen/types.js +16 -16
  153. package/lib/server/console.js +61 -57
  154. package/lib/server/cookieStore.js +206 -206
  155. package/lib/server/debugController.js +197 -191
  156. package/lib/server/debugger.js +112 -119
  157. package/lib/server/deviceDescriptors.js +39 -39
  158. package/lib/server/deviceDescriptorsSource.json +1778 -1778
  159. package/lib/server/dialog.js +116 -116
  160. package/lib/server/dispatchers/androidDispatcher.js +325 -325
  161. package/lib/server/dispatchers/artifactDispatcher.js +118 -118
  162. package/lib/server/dispatchers/browserContextDispatcher.js +381 -384
  163. package/lib/server/dispatchers/browserDispatcher.js +124 -118
  164. package/lib/server/dispatchers/browserTypeDispatcher.js +71 -64
  165. package/lib/server/dispatchers/cdpSessionDispatcher.js +47 -44
  166. package/lib/server/dispatchers/debugControllerDispatcher.js +78 -78
  167. package/lib/server/dispatchers/debuggerDispatcher.js +84 -0
  168. package/lib/server/dispatchers/dialogDispatcher.js +47 -47
  169. package/lib/server/dispatchers/dispatcher.js +364 -364
  170. package/lib/server/dispatchers/disposableDispatcher.js +39 -0
  171. package/lib/server/dispatchers/electronDispatcher.js +90 -89
  172. package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -181
  173. package/lib/server/dispatchers/frameDispatcher.js +227 -227
  174. package/lib/server/dispatchers/jsHandleDispatcher.js +85 -85
  175. package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -58
  176. package/lib/server/dispatchers/localUtilsDispatcher.js +185 -149
  177. package/lib/server/dispatchers/networkDispatchers.js +214 -213
  178. package/lib/server/dispatchers/pageDispatcher.js +456 -393
  179. package/lib/server/dispatchers/playwrightDispatcher.js +108 -108
  180. package/lib/server/dispatchers/streamDispatcher.js +67 -67
  181. package/lib/server/dispatchers/tracingDispatcher.js +68 -68
  182. package/lib/server/dispatchers/webSocketRouteDispatcher.js +164 -165
  183. package/lib/server/dispatchers/writableStreamDispatcher.js +79 -79
  184. package/lib/server/disposable.js +41 -0
  185. package/lib/server/dom.js +833 -815
  186. package/lib/server/download.js +71 -70
  187. package/lib/server/electron/electron.js +278 -273
  188. package/lib/server/electron/loader.js +29 -29
  189. package/lib/server/errors.js +69 -69
  190. package/lib/server/fetch.js +621 -621
  191. package/lib/server/fileChooser.js +43 -43
  192. package/lib/server/fileUploadUtils.js +84 -84
  193. package/lib/server/firefox/ffBrowser.js +408 -418
  194. package/lib/server/firefox/ffConnection.js +142 -142
  195. package/lib/server/firefox/ffExecutionContext.js +150 -150
  196. package/lib/server/firefox/ffInput.js +175 -159
  197. package/lib/server/firefox/ffNetworkManager.js +256 -256
  198. package/lib/server/firefox/ffPage.js +494 -497
  199. package/lib/server/firefox/firefox.js +114 -114
  200. package/lib/server/firefox/protocol.d.js +16 -16
  201. package/lib/server/formData.js +147 -147
  202. package/lib/server/frameSelectors.js +160 -160
  203. package/lib/server/frames.js +1500 -1471
  204. package/lib/server/har/harRecorder.js +147 -147
  205. package/lib/server/har/harTracer.js +608 -607
  206. package/lib/server/harBackend.js +157 -157
  207. package/lib/server/helper.js +96 -96
  208. package/lib/server/index.js +58 -58
  209. package/lib/server/input.js +322 -277
  210. package/lib/server/instrumentation.js +77 -72
  211. package/lib/server/javascript.js +291 -291
  212. package/lib/server/launchApp.js +127 -128
  213. package/lib/server/localUtils.js +214 -214
  214. package/lib/server/macEditingCommands.js +143 -143
  215. package/lib/server/network.js +668 -667
  216. package/lib/server/overlay.js +138 -0
  217. package/lib/server/page.js +890 -830
  218. package/lib/server/pipeTransport.js +89 -89
  219. package/lib/server/playwright.js +69 -69
  220. package/lib/server/progress.js +138 -132
  221. package/lib/server/protocolError.js +52 -52
  222. package/lib/server/recorder/chat.js +161 -161
  223. package/lib/server/recorder/recorderApp.js +367 -366
  224. package/lib/server/recorder/recorderRunner.js +138 -138
  225. package/lib/server/recorder/recorderSignalProcessor.js +83 -83
  226. package/lib/server/recorder/recorderUtils.js +157 -157
  227. package/lib/server/recorder/throttledFile.js +57 -57
  228. package/lib/server/recorder.js +535 -499
  229. package/lib/server/registry/browserFetcher.js +177 -177
  230. package/lib/server/registry/dependencies.js +371 -371
  231. package/lib/server/registry/index.js +1395 -1422
  232. package/lib/server/registry/nativeDeps.js +1281 -1280
  233. package/lib/server/registry/oopDownloadBrowserMain.js +127 -127
  234. package/lib/server/screencast.js +137 -190
  235. package/lib/server/screenshotter.js +333 -333
  236. package/lib/server/selectors.js +112 -112
  237. package/lib/server/socksClientCertificatesInterceptor.js +383 -383
  238. package/lib/server/socksInterceptor.js +95 -95
  239. package/lib/server/trace/recorder/snapshotter.js +147 -147
  240. package/lib/server/trace/recorder/snapshotterInjected.js +561 -561
  241. package/lib/server/trace/recorder/tracing.js +655 -604
  242. package/lib/server/trace/viewer/traceViewer.js +244 -245
  243. package/lib/server/transport.js +254 -254
  244. package/lib/server/types.js +28 -28
  245. package/lib/server/usKeyboardLayout.js +152 -145
  246. package/lib/server/utils/ascii.js +44 -44
  247. package/lib/server/utils/comparators.js +139 -139
  248. package/lib/server/utils/crypto.js +216 -216
  249. package/lib/server/utils/debug.js +42 -42
  250. package/lib/server/utils/debugLogger.js +122 -122
  251. package/lib/server/utils/disposable.js +32 -0
  252. package/lib/server/utils/env.js +73 -73
  253. package/lib/server/utils/eventsHelper.js +41 -39
  254. package/lib/server/utils/expectUtils.js +123 -123
  255. package/lib/server/utils/fileUtils.js +205 -191
  256. package/lib/server/utils/happyEyeballs.js +210 -207
  257. package/lib/server/utils/hostPlatform.js +123 -123
  258. package/lib/server/utils/httpServer.js +205 -203
  259. package/lib/server/utils/image_tools/colorUtils.js +89 -89
  260. package/lib/server/utils/image_tools/compare.js +109 -109
  261. package/lib/server/utils/image_tools/imageChannel.js +78 -78
  262. package/lib/server/utils/image_tools/stats.js +102 -102
  263. package/lib/server/utils/linuxUtils.js +71 -71
  264. package/lib/server/utils/network.js +243 -242
  265. package/lib/server/utils/nodePlatform.js +148 -154
  266. package/lib/server/utils/pipeTransport.js +84 -84
  267. package/lib/server/utils/processLauncher.js +243 -241
  268. package/lib/server/utils/profiler.js +65 -65
  269. package/lib/server/utils/socksProxy.js +511 -511
  270. package/lib/server/utils/spawnAsync.js +41 -41
  271. package/lib/server/utils/task.js +51 -51
  272. package/lib/server/utils/userAgent.js +98 -98
  273. package/lib/server/utils/wsServer.js +121 -121
  274. package/lib/server/utils/zipFile.js +74 -74
  275. package/lib/server/utils/zones.js +57 -57
  276. package/lib/server/videoRecorder.js +194 -124
  277. package/lib/server/webkit/protocol.d.js +16 -16
  278. package/lib/server/webkit/webkit.js +108 -108
  279. package/lib/server/webkit/wkBrowser.js +330 -335
  280. package/lib/server/webkit/wkConnection.js +144 -144
  281. package/lib/server/webkit/wkExecutionContext.js +154 -154
  282. package/lib/server/webkit/wkInput.js +181 -181
  283. package/lib/server/webkit/wkInterceptableRequest.js +197 -197
  284. package/lib/server/webkit/wkPage.js +1161 -1158
  285. package/lib/server/webkit/wkProvisionalPage.js +83 -83
  286. package/lib/server/webkit/wkWorkers.js +106 -105
  287. package/lib/serverRegistry.js +156 -0
  288. package/lib/third_party/pixelmatch.js +255 -255
  289. package/lib/tools/backend/browserBackend.js +79 -0
  290. package/lib/tools/backend/common.js +63 -0
  291. package/lib/tools/backend/config.js +41 -0
  292. package/lib/tools/backend/console.js +66 -0
  293. package/lib/tools/backend/context.js +296 -0
  294. package/lib/tools/backend/cookies.js +152 -0
  295. package/lib/tools/backend/devtools.js +69 -0
  296. package/lib/tools/backend/dialogs.js +59 -0
  297. package/lib/tools/backend/evaluate.js +64 -0
  298. package/lib/tools/backend/files.js +60 -0
  299. package/lib/tools/backend/form.js +64 -0
  300. package/lib/tools/backend/keyboard.js +155 -0
  301. package/lib/tools/backend/logFile.js +95 -0
  302. package/lib/tools/backend/mouse.js +168 -0
  303. package/lib/tools/backend/navigate.js +106 -0
  304. package/lib/tools/backend/network.js +135 -0
  305. package/lib/tools/backend/pdf.js +48 -0
  306. package/lib/tools/backend/response.js +305 -0
  307. package/lib/tools/backend/route.js +140 -0
  308. package/lib/tools/backend/runCode.js +77 -0
  309. package/lib/tools/backend/screenshot.js +88 -0
  310. package/lib/tools/backend/sessionLog.js +74 -0
  311. package/lib/tools/backend/snapshot.js +208 -0
  312. package/lib/tools/backend/storage.js +68 -0
  313. package/lib/tools/backend/tab.js +445 -0
  314. package/lib/tools/backend/tabs.js +67 -0
  315. package/lib/tools/backend/tool.js +47 -0
  316. package/lib/tools/backend/tools.js +102 -0
  317. package/lib/tools/backend/tracing.js +78 -0
  318. package/lib/tools/backend/utils.js +83 -0
  319. package/lib/tools/backend/verify.js +151 -0
  320. package/lib/tools/backend/video.js +98 -0
  321. package/lib/tools/backend/wait.js +63 -0
  322. package/lib/tools/backend/webstorage.js +223 -0
  323. package/lib/tools/cli-client/cli.js +6 -0
  324. package/lib/tools/cli-client/help.json +399 -0
  325. package/lib/tools/cli-client/minimist.js +128 -0
  326. package/lib/tools/cli-client/program.js +350 -0
  327. package/lib/tools/cli-client/registry.js +176 -0
  328. package/lib/tools/cli-client/session.js +289 -0
  329. package/lib/tools/cli-client/skill/SKILL.md +328 -0
  330. package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
  331. package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
  332. package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
  333. package/lib/tools/cli-client/skill/references/running-code.md +231 -0
  334. package/lib/tools/cli-client/skill/references/session-management.md +169 -0
  335. package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
  336. package/lib/tools/cli-client/skill/references/test-generation.md +88 -0
  337. package/lib/tools/cli-client/skill/references/tracing.md +139 -0
  338. package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
  339. package/lib/tools/cli-daemon/command.js +73 -0
  340. package/lib/tools/cli-daemon/commands.js +956 -0
  341. package/lib/tools/cli-daemon/daemon.js +157 -0
  342. package/lib/tools/cli-daemon/helpGenerator.js +177 -0
  343. package/lib/tools/cli-daemon/program.js +129 -0
  344. package/lib/tools/dashboard/appIcon.png +0 -0
  345. package/lib/tools/dashboard/dashboardApp.js +284 -0
  346. package/lib/tools/dashboard/dashboardController.js +296 -0
  347. package/lib/tools/exports.js +60 -0
  348. package/lib/tools/mcp/browserFactory.js +233 -0
  349. package/lib/tools/mcp/cdpRelay.js +352 -0
  350. package/lib/tools/mcp/cli-stub.js +7 -0
  351. package/lib/tools/mcp/config.d.js +16 -0
  352. package/lib/tools/mcp/config.js +446 -0
  353. package/lib/tools/mcp/configIni.js +189 -0
  354. package/lib/{server/trace/viewer/traceParser.js → tools/mcp/extensionContextFactory.js} +55 -72
  355. package/lib/tools/mcp/index.js +62 -0
  356. package/lib/tools/mcp/log.js +35 -0
  357. package/lib/tools/mcp/program.js +107 -0
  358. package/lib/tools/mcp/protocol.js +28 -0
  359. package/lib/tools/mcp/watchdog.js +44 -0
  360. package/lib/tools/trace/SKILL.md +171 -0
  361. package/lib/tools/trace/installSkill.js +48 -0
  362. package/lib/tools/trace/traceActions.js +142 -0
  363. package/lib/tools/trace/traceAttachments.js +69 -0
  364. package/lib/tools/trace/traceCli.js +87 -0
  365. package/lib/tools/trace/traceConsole.js +97 -0
  366. package/lib/tools/trace/traceErrors.js +55 -0
  367. package/lib/tools/trace/traceOpen.js +69 -0
  368. package/lib/tools/trace/traceParser.js +96 -0
  369. package/lib/tools/trace/traceRequests.js +182 -0
  370. package/lib/tools/trace/traceScreenshot.js +68 -0
  371. package/lib/tools/trace/traceSnapshot.js +149 -0
  372. package/lib/tools/trace/traceUtils.js +153 -0
  373. package/lib/tools/utils/connect.js +32 -0
  374. package/lib/tools/utils/mcp/http.js +152 -0
  375. package/lib/tools/utils/mcp/server.js +230 -0
  376. package/lib/tools/utils/mcp/tool.js +47 -0
  377. package/lib/tools/utils/socketConnection.js +108 -0
  378. package/lib/utils/isomorphic/ariaSnapshot.js +455 -455
  379. package/lib/utils/isomorphic/assert.js +31 -31
  380. package/lib/utils/isomorphic/colors.js +72 -72
  381. package/lib/utils/isomorphic/cssParser.js +245 -245
  382. package/lib/utils/isomorphic/cssTokenizer.js +1051 -1051
  383. package/lib/utils/isomorphic/formatUtils.js +64 -0
  384. package/lib/utils/isomorphic/headers.js +53 -53
  385. package/lib/{server/utils → utils/isomorphic}/imageUtils.js +141 -141
  386. package/lib/utils/isomorphic/jsonSchema.js +89 -0
  387. package/lib/utils/isomorphic/locatorGenerators.js +689 -689
  388. package/lib/utils/isomorphic/locatorParser.js +176 -176
  389. package/lib/utils/isomorphic/locatorUtils.js +81 -81
  390. package/lib/utils/isomorphic/lruCache.js +51 -51
  391. package/lib/utils/isomorphic/manualPromise.js +114 -114
  392. package/lib/utils/isomorphic/mimeType.js +464 -459
  393. package/lib/utils/isomorphic/multimap.js +80 -80
  394. package/lib/utils/isomorphic/protocolFormatter.js +81 -81
  395. package/lib/utils/isomorphic/protocolMetainfo.js +351 -330
  396. package/lib/utils/isomorphic/rtti.js +43 -43
  397. package/lib/utils/isomorphic/selectorParser.js +386 -386
  398. package/lib/utils/isomorphic/semaphore.js +54 -54
  399. package/lib/utils/isomorphic/stackTrace.js +158 -158
  400. package/lib/utils/isomorphic/stringUtils.js +204 -204
  401. package/lib/utils/isomorphic/time.js +49 -49
  402. package/lib/utils/isomorphic/timeoutRunner.js +66 -66
  403. package/lib/utils/isomorphic/trace/entries.js +16 -16
  404. package/lib/utils/isomorphic/trace/snapshotRenderer.js +492 -499
  405. package/lib/utils/isomorphic/trace/snapshotServer.js +120 -120
  406. package/lib/utils/isomorphic/trace/snapshotStorage.js +89 -89
  407. package/lib/utils/isomorphic/trace/traceLoader.js +132 -131
  408. package/lib/utils/isomorphic/trace/traceModel.js +366 -365
  409. package/lib/utils/isomorphic/trace/traceModernizer.js +401 -400
  410. package/lib/utils/isomorphic/{traceUtils.js → trace/traceUtils.js} +58 -58
  411. package/lib/utils/isomorphic/trace/versions/traceV3.js +16 -16
  412. package/lib/utils/isomorphic/trace/versions/traceV4.js +16 -16
  413. package/lib/utils/isomorphic/trace/versions/traceV5.js +16 -16
  414. package/lib/utils/isomorphic/trace/versions/traceV6.js +16 -16
  415. package/lib/utils/isomorphic/trace/versions/traceV7.js +16 -16
  416. package/lib/utils/isomorphic/trace/versions/traceV8.js +16 -16
  417. package/lib/utils/isomorphic/types.js +16 -16
  418. package/lib/utils/isomorphic/urlMatch.js +243 -190
  419. package/lib/utils/isomorphic/utilityScriptSerializers.js +262 -251
  420. package/lib/utils/isomorphic/yaml.js +84 -84
  421. package/lib/utils.js +115 -111
  422. package/lib/utilsBundle.js +91 -109
  423. package/lib/utilsBundleImpl/index.js +217 -218
  424. package/lib/utilsBundleImpl/xdg-open +1066 -1066
  425. package/lib/vite/dashboard/assets/index-BAOybkp8.js +50 -0
  426. package/lib/vite/dashboard/assets/index-CZAYOG76.css +1 -0
  427. package/lib/vite/dashboard/index.html +28 -0
  428. package/lib/vite/htmlReport/index.html +16 -84
  429. package/lib/vite/htmlReport/report.css +1 -0
  430. package/lib/vite/htmlReport/report.js +72 -0
  431. package/lib/vite/recorder/assets/{codeMirrorModule-DadYNm1I.js → codeMirrorModule-C8KMvO9L.js} +32 -32
  432. package/lib/vite/recorder/assets/codeMirrorModule-DYBRYzYX.css +1 -1
  433. package/lib/vite/recorder/assets/index-BSjZa4pk.css +1 -1
  434. package/lib/vite/recorder/assets/index-CqAYX1I3.js +193 -0
  435. package/lib/vite/recorder/index.html +29 -29
  436. package/lib/vite/recorder/playwright-logo.svg +9 -9
  437. package/lib/vite/traceViewer/assets/{codeMirrorModule-a5XoALAZ.js → codeMirrorModule-DS0FLvoc.js} +32 -32
  438. package/lib/vite/traceViewer/assets/defaultSettingsView-GTWI-W_B.js +262 -0
  439. package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -9
  440. package/lib/vite/traceViewer/codeMirrorModule.DYBRYzYX.css +1 -1
  441. package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
  442. package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
  443. package/lib/vite/traceViewer/{index.Bk2uYQRV.js → index.Dtstcb7U.js} +2 -2
  444. package/lib/vite/traceViewer/index.html +43 -43
  445. package/lib/vite/traceViewer/manifest.webmanifest +16 -16
  446. package/lib/vite/traceViewer/playwright-logo.svg +9 -9
  447. package/lib/vite/traceViewer/snapshot.html +21 -21
  448. package/lib/vite/traceViewer/sw.bundle.js +5 -5
  449. package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -1
  450. package/lib/vite/traceViewer/uiMode.Vipi55dB.js +6 -0
  451. package/lib/vite/traceViewer/uiMode.html +17 -17
  452. package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -32
  453. package/lib/zipBundle.js +34 -34
  454. package/lib/zipBundleImpl.js +5 -5
  455. package/lib/zodBundle.js +39 -0
  456. package/lib/zodBundleImpl.js +40 -0
  457. package/package.json +6 -1
  458. package/types/protocol.d.ts +24720 -23824
  459. package/types/structs.d.ts +45 -45
  460. package/types/types.d.ts +23623 -22843
  461. package/lib/client/pageAgent.js +0 -64
  462. package/lib/mcpBundleImpl/index.js +0 -147
  463. package/lib/server/agent/actionRunner.js +0 -335
  464. package/lib/server/agent/actions.js +0 -128
  465. package/lib/server/agent/codegen.js +0 -111
  466. package/lib/server/agent/context.js +0 -150
  467. package/lib/server/agent/expectTools.js +0 -156
  468. package/lib/server/agent/pageAgent.js +0 -204
  469. package/lib/server/agent/performTools.js +0 -262
  470. package/lib/server/agent/tool.js +0 -109
  471. package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
  472. package/lib/vite/recorder/assets/index-BhTWtUlo.js +0 -193
  473. package/lib/vite/traceViewer/assets/defaultSettingsView-CJSZINFr.js +0 -266
  474. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
  475. package/lib/vite/traceViewer/uiMode.CQJ9SCIQ.js +0 -5
@@ -1,747 +1,750 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var network_exports = {};
20
- __export(network_exports, {
21
- RawHeaders: () => RawHeaders,
22
- Request: () => Request,
23
- Response: () => Response,
24
- Route: () => Route,
25
- RouteHandler: () => RouteHandler,
26
- WebSocket: () => WebSocket,
27
- WebSocketRoute: () => WebSocketRoute,
28
- WebSocketRouteHandler: () => WebSocketRouteHandler,
29
- validateHeaders: () => validateHeaders
30
- });
31
- module.exports = __toCommonJS(network_exports);
32
- var import_channelOwner = require("./channelOwner");
33
- var import_errors = require("./errors");
34
- var import_events = require("./events");
35
- var import_fetch = require("./fetch");
36
- var import_frame = require("./frame");
37
- var import_waiter = require("./waiter");
38
- var import_worker = require("./worker");
39
- var import_assert = require("../utils/isomorphic/assert");
40
- var import_headers = require("../utils/isomorphic/headers");
41
- var import_urlMatch = require("../utils/isomorphic/urlMatch");
42
- var import_manualPromise = require("../utils/isomorphic/manualPromise");
43
- var import_multimap = require("../utils/isomorphic/multimap");
44
- var import_rtti = require("../utils/isomorphic/rtti");
45
- var import_stackTrace = require("../utils/isomorphic/stackTrace");
46
- var import_mimeType = require("../utils/isomorphic/mimeType");
47
- class Request extends import_channelOwner.ChannelOwner {
48
- constructor(parent, type, guid, initializer) {
49
- super(parent, type, guid, initializer);
50
- this._redirectedFrom = null;
51
- this._redirectedTo = null;
52
- this._failureText = null;
53
- this._fallbackOverrides = {};
54
- this._hasResponse = false;
55
- this._redirectedFrom = Request.fromNullable(initializer.redirectedFrom);
56
- if (this._redirectedFrom)
57
- this._redirectedFrom._redirectedTo = this;
58
- this._provisionalHeaders = new RawHeaders(initializer.headers);
59
- this._timing = {
60
- startTime: 0,
61
- domainLookupStart: -1,
62
- domainLookupEnd: -1,
63
- connectStart: -1,
64
- secureConnectionStart: -1,
65
- connectEnd: -1,
66
- requestStart: -1,
67
- responseStart: -1,
68
- responseEnd: -1
69
- };
70
- this._hasResponse = this._initializer.hasResponse;
71
- this._channel.on("response", () => this._hasResponse = true);
72
- }
73
- static from(request) {
74
- return request._object;
75
- }
76
- static fromNullable(request) {
77
- return request ? Request.from(request) : null;
78
- }
79
- url() {
80
- return this._fallbackOverrides.url || this._initializer.url;
81
- }
82
- resourceType() {
83
- return this._initializer.resourceType;
84
- }
85
- method() {
86
- return this._fallbackOverrides.method || this._initializer.method;
87
- }
88
- postData() {
89
- return (this._fallbackOverrides.postDataBuffer || this._initializer.postData)?.toString("utf-8") || null;
90
- }
91
- postDataBuffer() {
92
- return this._fallbackOverrides.postDataBuffer || this._initializer.postData || null;
93
- }
94
- postDataJSON() {
95
- const postData = this.postData();
96
- if (!postData)
97
- return null;
98
- const contentType = this.headers()["content-type"];
99
- if (contentType?.includes("application/x-www-form-urlencoded")) {
100
- const entries = {};
101
- const parsed = new URLSearchParams(postData);
102
- for (const [k, v] of parsed.entries())
103
- entries[k] = v;
104
- return entries;
105
- }
106
- try {
107
- return JSON.parse(postData);
108
- } catch (e) {
109
- throw new Error("POST data is not a valid JSON object: " + postData);
110
- }
111
- }
112
- /**
113
- * @deprecated
114
- */
115
- headers() {
116
- if (this._fallbackOverrides.headers)
117
- return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers).headers();
118
- return this._provisionalHeaders.headers();
119
- }
120
- async _actualHeaders() {
121
- if (this._fallbackOverrides.headers)
122
- return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers);
123
- if (!this._actualHeadersPromise) {
124
- this._actualHeadersPromise = this._wrapApiCall(async () => {
125
- return new RawHeaders((await this._channel.rawRequestHeaders()).headers);
126
- }, { internal: true });
127
- }
128
- return await this._actualHeadersPromise;
129
- }
130
- async allHeaders() {
131
- return (await this._actualHeaders()).headers();
132
- }
133
- async headersArray() {
134
- return (await this._actualHeaders()).headersArray();
135
- }
136
- async headerValue(name) {
137
- return (await this._actualHeaders()).get(name);
138
- }
139
- async response() {
140
- return Response.fromNullable((await this._channel.response()).response);
141
- }
142
- async _internalResponse() {
143
- return Response.fromNullable((await this._channel.response()).response);
144
- }
145
- frame() {
146
- if (!this._initializer.frame) {
147
- (0, import_assert.assert)(this.serviceWorker());
148
- throw new Error("Service Worker requests do not have an associated frame.");
149
- }
150
- const frame = import_frame.Frame.from(this._initializer.frame);
151
- if (!frame._page) {
152
- throw new Error([
153
- "Frame for this navigation request is not available, because the request",
154
- "was issued before the frame is created. You can check whether the request",
155
- "is a navigation request by calling isNavigationRequest() method."
156
- ].join("\n"));
157
- }
158
- return frame;
159
- }
160
- _safePage() {
161
- return import_frame.Frame.fromNullable(this._initializer.frame)?._page || null;
162
- }
163
- serviceWorker() {
164
- return this._initializer.serviceWorker ? import_worker.Worker.from(this._initializer.serviceWorker) : null;
165
- }
166
- isNavigationRequest() {
167
- return this._initializer.isNavigationRequest;
168
- }
169
- redirectedFrom() {
170
- return this._redirectedFrom;
171
- }
172
- redirectedTo() {
173
- return this._redirectedTo;
174
- }
175
- failure() {
176
- if (this._failureText === null)
177
- return null;
178
- return {
179
- errorText: this._failureText
180
- };
181
- }
182
- timing() {
183
- return this._timing;
184
- }
185
- async sizes() {
186
- const response = await this.response();
187
- if (!response)
188
- throw new Error("Unable to fetch sizes for failed request");
189
- return (await response._channel.sizes()).sizes;
190
- }
191
- _setResponseEndTiming(responseEndTiming) {
192
- this._timing.responseEnd = responseEndTiming;
193
- if (this._timing.responseStart === -1)
194
- this._timing.responseStart = responseEndTiming;
195
- }
196
- _finalRequest() {
197
- return this._redirectedTo ? this._redirectedTo._finalRequest() : this;
198
- }
199
- _applyFallbackOverrides(overrides) {
200
- if (overrides.url)
201
- this._fallbackOverrides.url = overrides.url;
202
- if (overrides.method)
203
- this._fallbackOverrides.method = overrides.method;
204
- if (overrides.headers)
205
- this._fallbackOverrides.headers = overrides.headers;
206
- if ((0, import_rtti.isString)(overrides.postData))
207
- this._fallbackOverrides.postDataBuffer = Buffer.from(overrides.postData, "utf-8");
208
- else if (overrides.postData instanceof Buffer)
209
- this._fallbackOverrides.postDataBuffer = overrides.postData;
210
- else if (overrides.postData)
211
- this._fallbackOverrides.postDataBuffer = Buffer.from(JSON.stringify(overrides.postData), "utf-8");
212
- }
213
- _fallbackOverridesForContinue() {
214
- return this._fallbackOverrides;
215
- }
216
- _targetClosedScope() {
217
- return this.serviceWorker()?._closedScope || this._safePage()?._closedOrCrashedScope || new import_manualPromise.LongStandingScope();
218
- }
219
- }
220
- class Route extends import_channelOwner.ChannelOwner {
221
- constructor(parent, type, guid, initializer) {
222
- super(parent, type, guid, initializer);
223
- this._handlingPromise = null;
224
- this._didThrow = false;
225
- }
226
- static from(route) {
227
- return route._object;
228
- }
229
- request() {
230
- return Request.from(this._initializer.request);
231
- }
232
- async _raceWithTargetClose(promise) {
233
- return await this.request()._targetClosedScope().safeRace(promise);
234
- }
235
- async _startHandling() {
236
- this._handlingPromise = new import_manualPromise.ManualPromise();
237
- return await this._handlingPromise;
238
- }
239
- async fallback(options = {}) {
240
- this._checkNotHandled();
241
- this.request()._applyFallbackOverrides(options);
242
- this._reportHandled(false);
243
- }
244
- async abort(errorCode) {
245
- await this._handleRoute(async () => {
246
- await this._raceWithTargetClose(this._channel.abort({ errorCode }));
247
- });
248
- }
249
- async _redirectNavigationRequest(url) {
250
- await this._handleRoute(async () => {
251
- await this._raceWithTargetClose(this._channel.redirectNavigationRequest({ url }));
252
- });
253
- }
254
- async fetch(options = {}) {
255
- return await this._wrapApiCall(async () => {
256
- return await this._context.request._innerFetch({ request: this.request(), data: options.postData, ...options });
257
- });
258
- }
259
- async fulfill(options = {}) {
260
- await this._handleRoute(async () => {
261
- await this._innerFulfill(options);
262
- });
263
- }
264
- async _handleRoute(callback) {
265
- this._checkNotHandled();
266
- try {
267
- await callback();
268
- this._reportHandled(true);
269
- } catch (e) {
270
- this._didThrow = true;
271
- throw e;
272
- }
273
- }
274
- async _innerFulfill(options = {}) {
275
- let fetchResponseUid;
276
- let { status: statusOption, headers: headersOption, body } = options;
277
- if (options.json !== void 0) {
278
- (0, import_assert.assert)(options.body === void 0, "Can specify either body or json parameters");
279
- body = JSON.stringify(options.json);
280
- }
281
- if (options.response instanceof import_fetch.APIResponse) {
282
- statusOption ??= options.response.status();
283
- headersOption ??= options.response.headers();
284
- if (body === void 0 && options.path === void 0) {
285
- if (options.response._request._connection === this._connection)
286
- fetchResponseUid = options.response._fetchUid();
287
- else
288
- body = await options.response.body();
289
- }
290
- }
291
- let isBase64 = false;
292
- let length = 0;
293
- if (options.path) {
294
- const buffer = await this._platform.fs().promises.readFile(options.path);
295
- body = buffer.toString("base64");
296
- isBase64 = true;
297
- length = buffer.length;
298
- } else if ((0, import_rtti.isString)(body)) {
299
- isBase64 = false;
300
- length = Buffer.byteLength(body);
301
- } else if (body) {
302
- length = body.length;
303
- body = body.toString("base64");
304
- isBase64 = true;
305
- }
306
- const headers = {};
307
- for (const header of Object.keys(headersOption || {}))
308
- headers[header.toLowerCase()] = String(headersOption[header]);
309
- if (options.contentType)
310
- headers["content-type"] = String(options.contentType);
311
- else if (options.json)
312
- headers["content-type"] = "application/json";
313
- else if (options.path)
314
- headers["content-type"] = (0, import_mimeType.getMimeTypeForPath)(options.path) || "application/octet-stream";
315
- if (length && !("content-length" in headers))
316
- headers["content-length"] = String(length);
317
- await this._raceWithTargetClose(this._channel.fulfill({
318
- status: statusOption || 200,
319
- headers: (0, import_headers.headersObjectToArray)(headers),
320
- body,
321
- isBase64,
322
- fetchResponseUid
323
- }));
324
- }
325
- async continue(options = {}) {
326
- await this._handleRoute(async () => {
327
- this.request()._applyFallbackOverrides(options);
328
- await this._innerContinue(
329
- false
330
- /* isFallback */
331
- );
332
- });
333
- }
334
- _checkNotHandled() {
335
- if (!this._handlingPromise)
336
- throw new Error("Route is already handled!");
337
- }
338
- _reportHandled(done) {
339
- const chain = this._handlingPromise;
340
- this._handlingPromise = null;
341
- chain.resolve(done);
342
- }
343
- async _innerContinue(isFallback) {
344
- const options = this.request()._fallbackOverridesForContinue();
345
- return await this._raceWithTargetClose(this._channel.continue({
346
- url: options.url,
347
- method: options.method,
348
- headers: options.headers ? (0, import_headers.headersObjectToArray)(options.headers) : void 0,
349
- postData: options.postDataBuffer,
350
- isFallback
351
- }));
352
- }
353
- }
354
- class WebSocketRoute extends import_channelOwner.ChannelOwner {
355
- constructor(parent, type, guid, initializer) {
356
- super(parent, type, guid, initializer);
357
- this._connected = false;
358
- this._server = {
359
- onMessage: (handler) => {
360
- this._onServerMessage = handler;
361
- },
362
- onClose: (handler) => {
363
- this._onServerClose = handler;
364
- },
365
- connectToServer: () => {
366
- throw new Error(`connectToServer must be called on the page-side WebSocketRoute`);
367
- },
368
- url: () => {
369
- return this._initializer.url;
370
- },
371
- close: async (options = {}) => {
372
- await this._channel.closeServer({ ...options, wasClean: true }).catch(() => {
373
- });
374
- },
375
- send: (message) => {
376
- if ((0, import_rtti.isString)(message))
377
- this._channel.sendToServer({ message, isBase64: false }).catch(() => {
378
- });
379
- else
380
- this._channel.sendToServer({ message: message.toString("base64"), isBase64: true }).catch(() => {
381
- });
382
- },
383
- async [Symbol.asyncDispose]() {
384
- await this.close();
385
- }
386
- };
387
- this._channel.on("messageFromPage", ({ message, isBase64 }) => {
388
- if (this._onPageMessage)
389
- this._onPageMessage(isBase64 ? Buffer.from(message, "base64") : message);
390
- else if (this._connected)
391
- this._channel.sendToServer({ message, isBase64 }).catch(() => {
392
- });
393
- });
394
- this._channel.on("messageFromServer", ({ message, isBase64 }) => {
395
- if (this._onServerMessage)
396
- this._onServerMessage(isBase64 ? Buffer.from(message, "base64") : message);
397
- else
398
- this._channel.sendToPage({ message, isBase64 }).catch(() => {
399
- });
400
- });
401
- this._channel.on("closePage", ({ code, reason, wasClean }) => {
402
- if (this._onPageClose)
403
- this._onPageClose(code, reason);
404
- else
405
- this._channel.closeServer({ code, reason, wasClean }).catch(() => {
406
- });
407
- });
408
- this._channel.on("closeServer", ({ code, reason, wasClean }) => {
409
- if (this._onServerClose)
410
- this._onServerClose(code, reason);
411
- else
412
- this._channel.closePage({ code, reason, wasClean }).catch(() => {
413
- });
414
- });
415
- }
416
- static from(route) {
417
- return route._object;
418
- }
419
- url() {
420
- return this._initializer.url;
421
- }
422
- async close(options = {}) {
423
- await this._channel.closePage({ ...options, wasClean: true }).catch(() => {
424
- });
425
- }
426
- connectToServer() {
427
- if (this._connected)
428
- throw new Error("Already connected to the server");
429
- this._connected = true;
430
- this._channel.connect().catch(() => {
431
- });
432
- return this._server;
433
- }
434
- send(message) {
435
- if ((0, import_rtti.isString)(message))
436
- this._channel.sendToPage({ message, isBase64: false }).catch(() => {
437
- });
438
- else
439
- this._channel.sendToPage({ message: message.toString("base64"), isBase64: true }).catch(() => {
440
- });
441
- }
442
- onMessage(handler) {
443
- this._onPageMessage = handler;
444
- }
445
- onClose(handler) {
446
- this._onPageClose = handler;
447
- }
448
- async [Symbol.asyncDispose]() {
449
- await this.close();
450
- }
451
- async _afterHandle() {
452
- if (this._connected)
453
- return;
454
- await this._channel.ensureOpened().catch(() => {
455
- });
456
- }
457
- }
458
- class WebSocketRouteHandler {
459
- constructor(baseURL, url, handler) {
460
- this._baseURL = baseURL;
461
- this.url = url;
462
- this.handler = handler;
463
- }
464
- static prepareInterceptionPatterns(handlers) {
465
- const patterns = [];
466
- let all = false;
467
- for (const handler of handlers) {
468
- if ((0, import_rtti.isString)(handler.url))
469
- patterns.push({ glob: handler.url });
470
- else if ((0, import_rtti.isRegExp)(handler.url))
471
- patterns.push({ regexSource: handler.url.source, regexFlags: handler.url.flags });
472
- else
473
- all = true;
474
- }
475
- if (all)
476
- return [{ glob: "**/*" }];
477
- return patterns;
478
- }
479
- matches(wsURL) {
480
- return (0, import_urlMatch.urlMatches)(this._baseURL, wsURL, this.url, true);
481
- }
482
- async handle(webSocketRoute) {
483
- const handler = this.handler;
484
- await handler(webSocketRoute);
485
- await webSocketRoute._afterHandle();
486
- }
487
- }
488
- class Response extends import_channelOwner.ChannelOwner {
489
- constructor(parent, type, guid, initializer) {
490
- super(parent, type, guid, initializer);
491
- this._finishedPromise = new import_manualPromise.ManualPromise();
492
- this._provisionalHeaders = new RawHeaders(initializer.headers);
493
- this._request = Request.from(this._initializer.request);
494
- Object.assign(this._request._timing, this._initializer.timing);
495
- }
496
- static from(response) {
497
- return response._object;
498
- }
499
- static fromNullable(response) {
500
- return response ? Response.from(response) : null;
501
- }
502
- url() {
503
- return this._initializer.url;
504
- }
505
- ok() {
506
- return this._initializer.status === 0 || this._initializer.status >= 200 && this._initializer.status <= 299;
507
- }
508
- status() {
509
- return this._initializer.status;
510
- }
511
- statusText() {
512
- return this._initializer.statusText;
513
- }
514
- fromServiceWorker() {
515
- return this._initializer.fromServiceWorker;
516
- }
517
- /**
518
- * @deprecated
519
- */
520
- headers() {
521
- return this._provisionalHeaders.headers();
522
- }
523
- async _actualHeaders() {
524
- if (!this._actualHeadersPromise) {
525
- this._actualHeadersPromise = (async () => {
526
- return new RawHeaders((await this._channel.rawResponseHeaders()).headers);
527
- })();
528
- }
529
- return await this._actualHeadersPromise;
530
- }
531
- async allHeaders() {
532
- return (await this._actualHeaders()).headers();
533
- }
534
- async headersArray() {
535
- return (await this._actualHeaders()).headersArray().slice();
536
- }
537
- async headerValue(name) {
538
- return (await this._actualHeaders()).get(name);
539
- }
540
- async headerValues(name) {
541
- return (await this._actualHeaders()).getAll(name);
542
- }
543
- async finished() {
544
- return await this.request()._targetClosedScope().race(this._finishedPromise);
545
- }
546
- async body() {
547
- return (await this._channel.body()).binary;
548
- }
549
- async text() {
550
- const content = await this.body();
551
- return content.toString("utf8");
552
- }
553
- async json() {
554
- const content = await this.text();
555
- return JSON.parse(content);
556
- }
557
- request() {
558
- return this._request;
559
- }
560
- frame() {
561
- return this._request.frame();
562
- }
563
- async serverAddr() {
564
- return (await this._channel.serverAddr()).value || null;
565
- }
566
- async securityDetails() {
567
- return (await this._channel.securityDetails()).value || null;
568
- }
569
- }
570
- class WebSocket extends import_channelOwner.ChannelOwner {
571
- static from(webSocket) {
572
- return webSocket._object;
573
- }
574
- constructor(parent, type, guid, initializer) {
575
- super(parent, type, guid, initializer);
576
- this._isClosed = false;
577
- this._page = parent;
578
- this._channel.on("frameSent", (event) => {
579
- if (event.opcode === 1)
580
- this.emit(import_events.Events.WebSocket.FrameSent, { payload: event.data });
581
- else if (event.opcode === 2)
582
- this.emit(import_events.Events.WebSocket.FrameSent, { payload: Buffer.from(event.data, "base64") });
583
- });
584
- this._channel.on("frameReceived", (event) => {
585
- if (event.opcode === 1)
586
- this.emit(import_events.Events.WebSocket.FrameReceived, { payload: event.data });
587
- else if (event.opcode === 2)
588
- this.emit(import_events.Events.WebSocket.FrameReceived, { payload: Buffer.from(event.data, "base64") });
589
- });
590
- this._channel.on("socketError", ({ error }) => this.emit(import_events.Events.WebSocket.Error, error));
591
- this._channel.on("close", () => {
592
- this._isClosed = true;
593
- this.emit(import_events.Events.WebSocket.Close, this);
594
- });
595
- }
596
- url() {
597
- return this._initializer.url;
598
- }
599
- isClosed() {
600
- return this._isClosed;
601
- }
602
- async waitForEvent(event, optionsOrPredicate = {}) {
603
- return await this._wrapApiCall(async () => {
604
- const timeout = this._page._timeoutSettings.timeout(typeof optionsOrPredicate === "function" ? {} : optionsOrPredicate);
605
- const predicate = typeof optionsOrPredicate === "function" ? optionsOrPredicate : optionsOrPredicate.predicate;
606
- const waiter = import_waiter.Waiter.createForEvent(this, event);
607
- waiter.rejectOnTimeout(timeout, `Timeout ${timeout}ms exceeded while waiting for event "${event}"`);
608
- if (event !== import_events.Events.WebSocket.Error)
609
- waiter.rejectOnEvent(this, import_events.Events.WebSocket.Error, new Error("Socket error"));
610
- if (event !== import_events.Events.WebSocket.Close)
611
- waiter.rejectOnEvent(this, import_events.Events.WebSocket.Close, new Error("Socket closed"));
612
- waiter.rejectOnEvent(this._page, import_events.Events.Page.Close, () => this._page._closeErrorWithReason());
613
- const result = await waiter.waitForEvent(this, event, predicate);
614
- waiter.dispose();
615
- return result;
616
- });
617
- }
618
- }
619
- function validateHeaders(headers) {
620
- for (const key of Object.keys(headers)) {
621
- const value = headers[key];
622
- if (!Object.is(value, void 0) && !(0, import_rtti.isString)(value))
623
- throw new Error(`Expected value of header "${key}" to be String, but "${typeof value}" is found.`);
624
- }
625
- }
626
- class RouteHandler {
627
- constructor(platform, baseURL, url, handler, times = Number.MAX_SAFE_INTEGER) {
628
- this.handledCount = 0;
629
- this._ignoreException = false;
630
- this._activeInvocations = /* @__PURE__ */ new Set();
631
- this._baseURL = baseURL;
632
- this._times = times;
633
- this.url = url;
634
- this.handler = handler;
635
- this._savedZone = platform.zones.current().pop();
636
- }
637
- static prepareInterceptionPatterns(handlers) {
638
- const patterns = [];
639
- let all = false;
640
- for (const handler of handlers) {
641
- if ((0, import_rtti.isString)(handler.url))
642
- patterns.push({ glob: handler.url });
643
- else if ((0, import_rtti.isRegExp)(handler.url))
644
- patterns.push({ regexSource: handler.url.source, regexFlags: handler.url.flags });
645
- else
646
- all = true;
647
- }
648
- if (all)
649
- return [{ glob: "**/*" }];
650
- return patterns;
651
- }
652
- matches(requestURL) {
653
- return (0, import_urlMatch.urlMatches)(this._baseURL, requestURL, this.url);
654
- }
655
- async handle(route) {
656
- return await this._savedZone.run(async () => this._handleImpl(route));
657
- }
658
- async _handleImpl(route) {
659
- const handlerInvocation = { complete: new import_manualPromise.ManualPromise(), route };
660
- this._activeInvocations.add(handlerInvocation);
661
- try {
662
- return await this._handleInternal(route);
663
- } catch (e) {
664
- if (this._ignoreException)
665
- return false;
666
- if ((0, import_errors.isTargetClosedError)(e)) {
667
- (0, import_stackTrace.rewriteErrorMessage)(e, `"${e.message}" while running route callback.
668
- Consider awaiting \`await page.unrouteAll({ behavior: 'ignoreErrors' })\`
669
- before the end of the test to ignore remaining routes in flight.`);
670
- }
671
- throw e;
672
- } finally {
673
- handlerInvocation.complete.resolve();
674
- this._activeInvocations.delete(handlerInvocation);
675
- }
676
- }
677
- async stop(behavior) {
678
- if (behavior === "ignoreErrors") {
679
- this._ignoreException = true;
680
- } else {
681
- const promises = [];
682
- for (const activation of this._activeInvocations) {
683
- if (!activation.route._didThrow)
684
- promises.push(activation.complete);
685
- }
686
- await Promise.all(promises);
687
- }
688
- }
689
- async _handleInternal(route) {
690
- ++this.handledCount;
691
- const handledPromise = route._startHandling();
692
- const handler = this.handler;
693
- const [handled] = await Promise.all([
694
- handledPromise,
695
- handler(route, route.request())
696
- ]);
697
- return handled;
698
- }
699
- willExpire() {
700
- return this.handledCount + 1 >= this._times;
701
- }
702
- }
703
- class RawHeaders {
704
- constructor(headers) {
705
- this._headersMap = new import_multimap.MultiMap();
706
- this._headersArray = headers;
707
- for (const header of headers)
708
- this._headersMap.set(header.name.toLowerCase(), header.value);
709
- }
710
- static _fromHeadersObjectLossy(headers) {
711
- const headersArray = Object.entries(headers).map(([name, value]) => ({
712
- name,
713
- value
714
- })).filter((header) => header.value !== void 0);
715
- return new RawHeaders(headersArray);
716
- }
717
- get(name) {
718
- const values = this.getAll(name);
719
- if (!values || !values.length)
720
- return null;
721
- return values.join(name.toLowerCase() === "set-cookie" ? "\n" : ", ");
722
- }
723
- getAll(name) {
724
- return [...this._headersMap.get(name.toLowerCase())];
725
- }
726
- headers() {
727
- const result = {};
728
- for (const name of this._headersMap.keys())
729
- result[name] = this.get(name);
730
- return result;
731
- }
732
- headersArray() {
733
- return this._headersArray;
734
- }
735
- }
736
- // Annotate the CommonJS export names for ESM import in node:
737
- 0 && (module.exports = {
738
- RawHeaders,
739
- Request,
740
- Response,
741
- Route,
742
- RouteHandler,
743
- WebSocket,
744
- WebSocketRoute,
745
- WebSocketRouteHandler,
746
- validateHeaders
747
- });
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var network_exports = {};
20
+ __export(network_exports, {
21
+ RawHeaders: () => RawHeaders,
22
+ Request: () => Request,
23
+ Response: () => Response,
24
+ Route: () => Route,
25
+ RouteHandler: () => RouteHandler,
26
+ WebSocket: () => WebSocket,
27
+ WebSocketRoute: () => WebSocketRoute,
28
+ WebSocketRouteHandler: () => WebSocketRouteHandler,
29
+ validateHeaders: () => validateHeaders
30
+ });
31
+ module.exports = __toCommonJS(network_exports);
32
+ var import_channelOwner = require("./channelOwner");
33
+ var import_errors = require("./errors");
34
+ var import_events = require("./events");
35
+ var import_fetch = require("./fetch");
36
+ var import_frame = require("./frame");
37
+ var import_waiter = require("./waiter");
38
+ var import_worker = require("./worker");
39
+ var import_assert = require("../utils/isomorphic/assert");
40
+ var import_headers = require("../utils/isomorphic/headers");
41
+ var import_urlMatch = require("../utils/isomorphic/urlMatch");
42
+ var import_manualPromise = require("../utils/isomorphic/manualPromise");
43
+ var import_multimap = require("../utils/isomorphic/multimap");
44
+ var import_rtti = require("../utils/isomorphic/rtti");
45
+ var import_stackTrace = require("../utils/isomorphic/stackTrace");
46
+ var import_mimeType = require("../utils/isomorphic/mimeType");
47
+ class Request extends import_channelOwner.ChannelOwner {
48
+ constructor(parent, type, guid, initializer) {
49
+ super(parent, type, guid, initializer);
50
+ this._redirectedFrom = null;
51
+ this._redirectedTo = null;
52
+ this._failureText = null;
53
+ this._response = null;
54
+ this._fallbackOverrides = {};
55
+ this._redirectedFrom = Request.fromNullable(initializer.redirectedFrom);
56
+ if (this._redirectedFrom)
57
+ this._redirectedFrom._redirectedTo = this;
58
+ this._provisionalHeaders = new RawHeaders(initializer.headers);
59
+ this._timing = {
60
+ startTime: 0,
61
+ domainLookupStart: -1,
62
+ domainLookupEnd: -1,
63
+ connectStart: -1,
64
+ secureConnectionStart: -1,
65
+ connectEnd: -1,
66
+ requestStart: -1,
67
+ responseStart: -1,
68
+ responseEnd: -1
69
+ };
70
+ }
71
+ static from(request) {
72
+ return request._object;
73
+ }
74
+ static fromNullable(request) {
75
+ return request ? Request.from(request) : null;
76
+ }
77
+ url() {
78
+ return this._fallbackOverrides.url || this._initializer.url;
79
+ }
80
+ resourceType() {
81
+ return this._initializer.resourceType;
82
+ }
83
+ method() {
84
+ return this._fallbackOverrides.method || this._initializer.method;
85
+ }
86
+ postData() {
87
+ return (this._fallbackOverrides.postDataBuffer || this._initializer.postData)?.toString("utf-8") || null;
88
+ }
89
+ postDataBuffer() {
90
+ return this._fallbackOverrides.postDataBuffer || this._initializer.postData || null;
91
+ }
92
+ postDataJSON() {
93
+ const postData = this.postData();
94
+ if (!postData)
95
+ return null;
96
+ const contentType = this.headers()["content-type"];
97
+ if (contentType?.includes("application/x-www-form-urlencoded")) {
98
+ const entries = {};
99
+ const parsed = new URLSearchParams(postData);
100
+ for (const [k, v] of parsed.entries())
101
+ entries[k] = v;
102
+ return entries;
103
+ }
104
+ try {
105
+ return JSON.parse(postData);
106
+ } catch (e) {
107
+ throw new Error("POST data is not a valid JSON object: " + postData);
108
+ }
109
+ }
110
+ /**
111
+ * @deprecated
112
+ */
113
+ headers() {
114
+ if (this._fallbackOverrides.headers)
115
+ return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers).headers();
116
+ return this._provisionalHeaders.headers();
117
+ }
118
+ async _actualHeaders() {
119
+ if (this._fallbackOverrides.headers)
120
+ return RawHeaders._fromHeadersObjectLossy(this._fallbackOverrides.headers);
121
+ if (!this._actualHeadersPromise) {
122
+ this._actualHeadersPromise = this._wrapApiCall(async () => {
123
+ return new RawHeaders((await this._channel.rawRequestHeaders()).headers);
124
+ }, { internal: true });
125
+ }
126
+ return await this._actualHeadersPromise;
127
+ }
128
+ async allHeaders() {
129
+ return (await this._actualHeaders()).headers();
130
+ }
131
+ async headersArray() {
132
+ return (await this._actualHeaders()).headersArray();
133
+ }
134
+ async headerValue(name) {
135
+ return (await this._actualHeaders()).get(name);
136
+ }
137
+ async response() {
138
+ return Response.fromNullable((await this._channel.response()).response);
139
+ }
140
+ async _internalResponse() {
141
+ return Response.fromNullable((await this._channel.response()).response);
142
+ }
143
+ existingResponse() {
144
+ return this._response;
145
+ }
146
+ frame() {
147
+ if (!this._initializer.frame) {
148
+ (0, import_assert.assert)(this.serviceWorker());
149
+ throw new Error("Service Worker requests do not have an associated frame.");
150
+ }
151
+ const frame = import_frame.Frame.from(this._initializer.frame);
152
+ if (!frame._page) {
153
+ throw new Error([
154
+ "Frame for this navigation request is not available, because the request",
155
+ "was issued before the frame is created. You can check whether the request",
156
+ "is a navigation request by calling isNavigationRequest() method."
157
+ ].join("\n"));
158
+ }
159
+ return frame;
160
+ }
161
+ _safePage() {
162
+ return import_frame.Frame.fromNullable(this._initializer.frame)?._page || null;
163
+ }
164
+ serviceWorker() {
165
+ return this._initializer.serviceWorker ? import_worker.Worker.from(this._initializer.serviceWorker) : null;
166
+ }
167
+ isNavigationRequest() {
168
+ return this._initializer.isNavigationRequest;
169
+ }
170
+ redirectedFrom() {
171
+ return this._redirectedFrom;
172
+ }
173
+ redirectedTo() {
174
+ return this._redirectedTo;
175
+ }
176
+ failure() {
177
+ if (this._failureText === null)
178
+ return null;
179
+ return {
180
+ errorText: this._failureText
181
+ };
182
+ }
183
+ timing() {
184
+ return this._timing;
185
+ }
186
+ async sizes() {
187
+ const response = await this.response();
188
+ if (!response)
189
+ throw new Error("Unable to fetch sizes for failed request");
190
+ return (await response._channel.sizes()).sizes;
191
+ }
192
+ _setResponseEndTiming(responseEndTiming) {
193
+ this._timing.responseEnd = responseEndTiming;
194
+ if (this._timing.responseStart === -1)
195
+ this._timing.responseStart = responseEndTiming;
196
+ }
197
+ _finalRequest() {
198
+ return this._redirectedTo ? this._redirectedTo._finalRequest() : this;
199
+ }
200
+ _applyFallbackOverrides(overrides) {
201
+ if (overrides.url)
202
+ this._fallbackOverrides.url = overrides.url;
203
+ if (overrides.method)
204
+ this._fallbackOverrides.method = overrides.method;
205
+ if (overrides.headers)
206
+ this._fallbackOverrides.headers = overrides.headers;
207
+ if ((0, import_rtti.isString)(overrides.postData))
208
+ this._fallbackOverrides.postDataBuffer = Buffer.from(overrides.postData, "utf-8");
209
+ else if (overrides.postData instanceof Buffer)
210
+ this._fallbackOverrides.postDataBuffer = overrides.postData;
211
+ else if (overrides.postData)
212
+ this._fallbackOverrides.postDataBuffer = Buffer.from(JSON.stringify(overrides.postData), "utf-8");
213
+ }
214
+ _fallbackOverridesForContinue() {
215
+ return this._fallbackOverrides;
216
+ }
217
+ _targetClosedScope() {
218
+ return this.serviceWorker()?._closedScope || this._safePage()?._closedOrCrashedScope || new import_manualPromise.LongStandingScope();
219
+ }
220
+ }
221
+ class Route extends import_channelOwner.ChannelOwner {
222
+ constructor(parent, type, guid, initializer) {
223
+ super(parent, type, guid, initializer);
224
+ this._handlingPromise = null;
225
+ this._didThrow = false;
226
+ }
227
+ static from(route) {
228
+ return route._object;
229
+ }
230
+ request() {
231
+ return Request.from(this._initializer.request);
232
+ }
233
+ async _raceWithTargetClose(promise) {
234
+ return await this.request()._targetClosedScope().safeRace(promise);
235
+ }
236
+ async _startHandling() {
237
+ this._handlingPromise = new import_manualPromise.ManualPromise();
238
+ return await this._handlingPromise;
239
+ }
240
+ async fallback(options = {}) {
241
+ this._checkNotHandled();
242
+ this.request()._applyFallbackOverrides(options);
243
+ this._reportHandled(false);
244
+ }
245
+ async abort(errorCode) {
246
+ await this._handleRoute(async () => {
247
+ await this._raceWithTargetClose(this._channel.abort({ errorCode }));
248
+ });
249
+ }
250
+ async _redirectNavigationRequest(url) {
251
+ await this._handleRoute(async () => {
252
+ await this._raceWithTargetClose(this._channel.redirectNavigationRequest({ url }));
253
+ });
254
+ }
255
+ async fetch(options = {}) {
256
+ return await this._wrapApiCall(async () => {
257
+ return await this._context.request._innerFetch({ request: this.request(), data: options.postData, ...options });
258
+ });
259
+ }
260
+ async fulfill(options = {}) {
261
+ await this._handleRoute(async () => {
262
+ await this._innerFulfill(options);
263
+ });
264
+ }
265
+ async _handleRoute(callback) {
266
+ this._checkNotHandled();
267
+ try {
268
+ await callback();
269
+ this._reportHandled(true);
270
+ } catch (e) {
271
+ this._didThrow = true;
272
+ throw e;
273
+ }
274
+ }
275
+ async _innerFulfill(options = {}) {
276
+ let fetchResponseUid;
277
+ let { status: statusOption, headers: headersOption, body } = options;
278
+ if (options.json !== void 0) {
279
+ (0, import_assert.assert)(options.body === void 0, "Can specify either body or json parameters");
280
+ body = JSON.stringify(options.json);
281
+ }
282
+ if (options.response instanceof import_fetch.APIResponse) {
283
+ statusOption ??= options.response.status();
284
+ headersOption ??= options.response.headers();
285
+ if (body === void 0 && options.path === void 0) {
286
+ if (options.response._request._connection === this._connection)
287
+ fetchResponseUid = options.response._fetchUid();
288
+ else
289
+ body = await options.response.body();
290
+ }
291
+ }
292
+ let isBase64 = false;
293
+ let length = 0;
294
+ if (options.path) {
295
+ const buffer = await this._platform.fs().promises.readFile(options.path);
296
+ body = buffer.toString("base64");
297
+ isBase64 = true;
298
+ length = buffer.length;
299
+ } else if ((0, import_rtti.isString)(body)) {
300
+ isBase64 = false;
301
+ length = Buffer.byteLength(body);
302
+ } else if (body) {
303
+ length = body.length;
304
+ body = body.toString("base64");
305
+ isBase64 = true;
306
+ }
307
+ const headers = {};
308
+ for (const header of Object.keys(headersOption || {}))
309
+ headers[header.toLowerCase()] = String(headersOption[header]);
310
+ if (options.contentType)
311
+ headers["content-type"] = String(options.contentType);
312
+ else if (options.json)
313
+ headers["content-type"] = "application/json";
314
+ else if (options.path)
315
+ headers["content-type"] = (0, import_mimeType.getMimeTypeForPath)(options.path) || "application/octet-stream";
316
+ if (length && !("content-length" in headers))
317
+ headers["content-length"] = String(length);
318
+ await this._raceWithTargetClose(this._channel.fulfill({
319
+ status: statusOption || 200,
320
+ headers: (0, import_headers.headersObjectToArray)(headers),
321
+ body,
322
+ isBase64,
323
+ fetchResponseUid
324
+ }));
325
+ }
326
+ async continue(options = {}) {
327
+ await this._handleRoute(async () => {
328
+ this.request()._applyFallbackOverrides(options);
329
+ await this._innerContinue(
330
+ false
331
+ /* isFallback */
332
+ );
333
+ });
334
+ }
335
+ _checkNotHandled() {
336
+ if (!this._handlingPromise)
337
+ throw new Error("Route is already handled!");
338
+ }
339
+ _reportHandled(done) {
340
+ const chain = this._handlingPromise;
341
+ this._handlingPromise = null;
342
+ chain.resolve(done);
343
+ }
344
+ async _innerContinue(isFallback) {
345
+ const options = this.request()._fallbackOverridesForContinue();
346
+ return await this._raceWithTargetClose(this._channel.continue({
347
+ url: options.url,
348
+ method: options.method,
349
+ headers: options.headers ? (0, import_headers.headersObjectToArray)(options.headers) : void 0,
350
+ postData: options.postDataBuffer,
351
+ isFallback
352
+ }));
353
+ }
354
+ }
355
+ class WebSocketRoute extends import_channelOwner.ChannelOwner {
356
+ constructor(parent, type, guid, initializer) {
357
+ super(parent, type, guid, initializer);
358
+ this._connected = false;
359
+ this._server = {
360
+ onMessage: (handler) => {
361
+ this._onServerMessage = handler;
362
+ },
363
+ onClose: (handler) => {
364
+ this._onServerClose = handler;
365
+ },
366
+ connectToServer: () => {
367
+ throw new Error(`connectToServer must be called on the page-side WebSocketRoute`);
368
+ },
369
+ url: () => {
370
+ return this._initializer.url;
371
+ },
372
+ close: async (options = {}) => {
373
+ await this._channel.closeServer({ ...options, wasClean: true }).catch(() => {
374
+ });
375
+ },
376
+ send: (message) => {
377
+ if ((0, import_rtti.isString)(message))
378
+ this._channel.sendToServer({ message, isBase64: false }).catch(() => {
379
+ });
380
+ else
381
+ this._channel.sendToServer({ message: message.toString("base64"), isBase64: true }).catch(() => {
382
+ });
383
+ },
384
+ async [Symbol.asyncDispose]() {
385
+ await this.close();
386
+ }
387
+ };
388
+ this._channel.on("messageFromPage", ({ message, isBase64 }) => {
389
+ if (this._onPageMessage)
390
+ this._onPageMessage(isBase64 ? Buffer.from(message, "base64") : message);
391
+ else if (this._connected)
392
+ this._channel.sendToServer({ message, isBase64 }).catch(() => {
393
+ });
394
+ });
395
+ this._channel.on("messageFromServer", ({ message, isBase64 }) => {
396
+ if (this._onServerMessage)
397
+ this._onServerMessage(isBase64 ? Buffer.from(message, "base64") : message);
398
+ else
399
+ this._channel.sendToPage({ message, isBase64 }).catch(() => {
400
+ });
401
+ });
402
+ this._channel.on("closePage", ({ code, reason, wasClean }) => {
403
+ if (this._onPageClose)
404
+ this._onPageClose(code, reason);
405
+ else
406
+ this._channel.closeServer({ code, reason, wasClean }).catch(() => {
407
+ });
408
+ });
409
+ this._channel.on("closeServer", ({ code, reason, wasClean }) => {
410
+ if (this._onServerClose)
411
+ this._onServerClose(code, reason);
412
+ else
413
+ this._channel.closePage({ code, reason, wasClean }).catch(() => {
414
+ });
415
+ });
416
+ }
417
+ static from(route) {
418
+ return route._object;
419
+ }
420
+ url() {
421
+ return this._initializer.url;
422
+ }
423
+ async close(options = {}) {
424
+ await this._channel.closePage({ ...options, wasClean: true }).catch(() => {
425
+ });
426
+ }
427
+ connectToServer() {
428
+ if (this._connected)
429
+ throw new Error("Already connected to the server");
430
+ this._connected = true;
431
+ this._channel.connect().catch(() => {
432
+ });
433
+ return this._server;
434
+ }
435
+ send(message) {
436
+ if ((0, import_rtti.isString)(message))
437
+ this._channel.sendToPage({ message, isBase64: false }).catch(() => {
438
+ });
439
+ else
440
+ this._channel.sendToPage({ message: message.toString("base64"), isBase64: true }).catch(() => {
441
+ });
442
+ }
443
+ onMessage(handler) {
444
+ this._onPageMessage = handler;
445
+ }
446
+ onClose(handler) {
447
+ this._onPageClose = handler;
448
+ }
449
+ async [Symbol.asyncDispose]() {
450
+ await this.close();
451
+ }
452
+ async _afterHandle() {
453
+ if (this._connected)
454
+ return;
455
+ await this._channel.ensureOpened().catch(() => {
456
+ });
457
+ }
458
+ }
459
+ class WebSocketRouteHandler {
460
+ constructor(baseURL, url, handler) {
461
+ this._baseURL = baseURL;
462
+ this.url = url;
463
+ this.handler = handler;
464
+ }
465
+ static prepareInterceptionPatterns(handlers) {
466
+ const patterns = [];
467
+ let all = false;
468
+ for (const handler of handlers) {
469
+ const serialized = (0, import_urlMatch.serializeURLMatch)(handler.url);
470
+ if (serialized)
471
+ patterns.push(serialized);
472
+ else
473
+ all = true;
474
+ }
475
+ if (all)
476
+ return [{ glob: "**/*" }];
477
+ return patterns;
478
+ }
479
+ matches(wsURL) {
480
+ return (0, import_urlMatch.urlMatches)(this._baseURL, wsURL, this.url, true);
481
+ }
482
+ async handle(webSocketRoute) {
483
+ const handler = this.handler;
484
+ await handler(webSocketRoute);
485
+ await webSocketRoute._afterHandle();
486
+ }
487
+ }
488
+ class Response extends import_channelOwner.ChannelOwner {
489
+ constructor(parent, type, guid, initializer) {
490
+ super(parent, type, guid, initializer);
491
+ this._finishedPromise = new import_manualPromise.ManualPromise();
492
+ this._provisionalHeaders = new RawHeaders(initializer.headers);
493
+ this._request = Request.from(this._initializer.request);
494
+ this._request._response = this;
495
+ Object.assign(this._request._timing, this._initializer.timing);
496
+ }
497
+ static from(response) {
498
+ return response._object;
499
+ }
500
+ static fromNullable(response) {
501
+ return response ? Response.from(response) : null;
502
+ }
503
+ url() {
504
+ return this._initializer.url;
505
+ }
506
+ ok() {
507
+ return this._initializer.status === 0 || this._initializer.status >= 200 && this._initializer.status <= 299;
508
+ }
509
+ status() {
510
+ return this._initializer.status;
511
+ }
512
+ statusText() {
513
+ return this._initializer.statusText;
514
+ }
515
+ fromServiceWorker() {
516
+ return this._initializer.fromServiceWorker;
517
+ }
518
+ /**
519
+ * @deprecated
520
+ */
521
+ headers() {
522
+ return this._provisionalHeaders.headers();
523
+ }
524
+ async _actualHeaders() {
525
+ if (!this._actualHeadersPromise) {
526
+ this._actualHeadersPromise = (async () => {
527
+ return new RawHeaders((await this._channel.rawResponseHeaders()).headers);
528
+ })();
529
+ }
530
+ return await this._actualHeadersPromise;
531
+ }
532
+ async allHeaders() {
533
+ return (await this._actualHeaders()).headers();
534
+ }
535
+ async headersArray() {
536
+ return (await this._actualHeaders()).headersArray().slice();
537
+ }
538
+ async headerValue(name) {
539
+ return (await this._actualHeaders()).get(name);
540
+ }
541
+ async headerValues(name) {
542
+ return (await this._actualHeaders()).getAll(name);
543
+ }
544
+ async finished() {
545
+ return await this.request()._targetClosedScope().race(this._finishedPromise);
546
+ }
547
+ async body() {
548
+ return (await this._channel.body()).binary;
549
+ }
550
+ async text() {
551
+ const content = await this.body();
552
+ return content.toString("utf8");
553
+ }
554
+ async json() {
555
+ const content = await this.text();
556
+ return JSON.parse(content);
557
+ }
558
+ request() {
559
+ return this._request;
560
+ }
561
+ frame() {
562
+ return this._request.frame();
563
+ }
564
+ async serverAddr() {
565
+ return (await this._channel.serverAddr()).value || null;
566
+ }
567
+ async securityDetails() {
568
+ return (await this._channel.securityDetails()).value || null;
569
+ }
570
+ async httpVersion() {
571
+ return (await this._channel.httpVersion()).value;
572
+ }
573
+ }
574
+ class WebSocket extends import_channelOwner.ChannelOwner {
575
+ static from(webSocket) {
576
+ return webSocket._object;
577
+ }
578
+ constructor(parent, type, guid, initializer) {
579
+ super(parent, type, guid, initializer);
580
+ this._isClosed = false;
581
+ this._page = parent;
582
+ this._channel.on("frameSent", (event) => {
583
+ if (event.opcode === 1)
584
+ this.emit(import_events.Events.WebSocket.FrameSent, { payload: event.data });
585
+ else if (event.opcode === 2)
586
+ this.emit(import_events.Events.WebSocket.FrameSent, { payload: Buffer.from(event.data, "base64") });
587
+ });
588
+ this._channel.on("frameReceived", (event) => {
589
+ if (event.opcode === 1)
590
+ this.emit(import_events.Events.WebSocket.FrameReceived, { payload: event.data });
591
+ else if (event.opcode === 2)
592
+ this.emit(import_events.Events.WebSocket.FrameReceived, { payload: Buffer.from(event.data, "base64") });
593
+ });
594
+ this._channel.on("socketError", ({ error }) => this.emit(import_events.Events.WebSocket.Error, error));
595
+ this._channel.on("close", () => {
596
+ this._isClosed = true;
597
+ this.emit(import_events.Events.WebSocket.Close, this);
598
+ });
599
+ }
600
+ url() {
601
+ return this._initializer.url;
602
+ }
603
+ isClosed() {
604
+ return this._isClosed;
605
+ }
606
+ async waitForEvent(event, optionsOrPredicate = {}) {
607
+ return await this._wrapApiCall(async () => {
608
+ const timeout = this._page._timeoutSettings.timeout(typeof optionsOrPredicate === "function" ? {} : optionsOrPredicate);
609
+ const predicate = typeof optionsOrPredicate === "function" ? optionsOrPredicate : optionsOrPredicate.predicate;
610
+ const waiter = import_waiter.Waiter.createForEvent(this, event);
611
+ waiter.rejectOnTimeout(timeout, `Timeout ${timeout}ms exceeded while waiting for event "${event}"`);
612
+ if (event !== import_events.Events.WebSocket.Error)
613
+ waiter.rejectOnEvent(this, import_events.Events.WebSocket.Error, new Error("Socket error"));
614
+ if (event !== import_events.Events.WebSocket.Close)
615
+ waiter.rejectOnEvent(this, import_events.Events.WebSocket.Close, new Error("Socket closed"));
616
+ waiter.rejectOnEvent(this._page, import_events.Events.Page.Close, () => this._page._closeErrorWithReason());
617
+ const result = await waiter.waitForEvent(this, event, predicate);
618
+ waiter.dispose();
619
+ return result;
620
+ });
621
+ }
622
+ }
623
+ function validateHeaders(headers) {
624
+ for (const key of Object.keys(headers)) {
625
+ const value = headers[key];
626
+ if (!Object.is(value, void 0) && !(0, import_rtti.isString)(value))
627
+ throw new Error(`Expected value of header "${key}" to be String, but "${typeof value}" is found.`);
628
+ }
629
+ }
630
+ class RouteHandler {
631
+ constructor(platform, baseURL, url, handler, times = Number.MAX_SAFE_INTEGER) {
632
+ this.handledCount = 0;
633
+ this._ignoreException = false;
634
+ this._activeInvocations = /* @__PURE__ */ new Set();
635
+ this._baseURL = baseURL;
636
+ this._times = times;
637
+ this.url = url;
638
+ this.handler = handler;
639
+ this._savedZone = platform.zones.current().pop();
640
+ }
641
+ static prepareInterceptionPatterns(handlers) {
642
+ const patterns = [];
643
+ let all = false;
644
+ for (const handler of handlers) {
645
+ const serialized = (0, import_urlMatch.serializeURLMatch)(handler.url);
646
+ if (serialized)
647
+ patterns.push(serialized);
648
+ else
649
+ all = true;
650
+ }
651
+ if (all)
652
+ return [{ glob: "**/*" }];
653
+ return patterns;
654
+ }
655
+ matches(requestURL) {
656
+ return (0, import_urlMatch.urlMatches)(this._baseURL, requestURL, this.url);
657
+ }
658
+ async handle(route) {
659
+ return await this._savedZone.run(async () => this._handleImpl(route));
660
+ }
661
+ async _handleImpl(route) {
662
+ const handlerInvocation = { complete: new import_manualPromise.ManualPromise(), route };
663
+ this._activeInvocations.add(handlerInvocation);
664
+ try {
665
+ return await this._handleInternal(route);
666
+ } catch (e) {
667
+ if (this._ignoreException)
668
+ return false;
669
+ if ((0, import_errors.isTargetClosedError)(e)) {
670
+ (0, import_stackTrace.rewriteErrorMessage)(e, `"${e.message}" while running route callback.
671
+ Consider awaiting \`await page.unrouteAll({ behavior: 'ignoreErrors' })\`
672
+ before the end of the test to ignore remaining routes in flight.`);
673
+ }
674
+ throw e;
675
+ } finally {
676
+ handlerInvocation.complete.resolve();
677
+ this._activeInvocations.delete(handlerInvocation);
678
+ }
679
+ }
680
+ async stop(behavior) {
681
+ if (behavior === "ignoreErrors") {
682
+ this._ignoreException = true;
683
+ } else {
684
+ const promises = [];
685
+ for (const activation of this._activeInvocations) {
686
+ if (!activation.route._didThrow)
687
+ promises.push(activation.complete);
688
+ }
689
+ await Promise.all(promises);
690
+ }
691
+ }
692
+ async _handleInternal(route) {
693
+ ++this.handledCount;
694
+ const handledPromise = route._startHandling();
695
+ const handler = this.handler;
696
+ const [handled] = await Promise.all([
697
+ handledPromise,
698
+ handler(route, route.request())
699
+ ]);
700
+ return handled;
701
+ }
702
+ willExpire() {
703
+ return this.handledCount + 1 >= this._times;
704
+ }
705
+ }
706
+ class RawHeaders {
707
+ constructor(headers) {
708
+ this._headersMap = new import_multimap.MultiMap();
709
+ this._headersArray = headers;
710
+ for (const header of headers)
711
+ this._headersMap.set(header.name.toLowerCase(), header.value);
712
+ }
713
+ static _fromHeadersObjectLossy(headers) {
714
+ const headersArray = Object.entries(headers).map(([name, value]) => ({
715
+ name,
716
+ value
717
+ })).filter((header) => header.value !== void 0);
718
+ return new RawHeaders(headersArray);
719
+ }
720
+ get(name) {
721
+ const values = this.getAll(name);
722
+ if (!values || !values.length)
723
+ return null;
724
+ return values.join(name.toLowerCase() === "set-cookie" ? "\n" : ", ");
725
+ }
726
+ getAll(name) {
727
+ return [...this._headersMap.get(name.toLowerCase())];
728
+ }
729
+ headers() {
730
+ const result = {};
731
+ for (const name of this._headersMap.keys())
732
+ result[name] = this.get(name);
733
+ return result;
734
+ }
735
+ headersArray() {
736
+ return this._headersArray;
737
+ }
738
+ }
739
+ // Annotate the CommonJS export names for ESM import in node:
740
+ 0 && (module.exports = {
741
+ RawHeaders,
742
+ Request,
743
+ Response,
744
+ Route,
745
+ RouteHandler,
746
+ WebSocket,
747
+ WebSocketRoute,
748
+ WebSocketRouteHandler,
749
+ validateHeaders
750
+ });