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,702 +1,741 @@
1
- "use strict";
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var browserContext_exports = {};
30
- __export(browserContext_exports, {
31
- BrowserContext: () => BrowserContext,
32
- normalizeProxySettings: () => normalizeProxySettings,
33
- validateBrowserContextOptions: () => validateBrowserContextOptions,
34
- verifyClientCertificates: () => verifyClientCertificates,
35
- verifyGeolocation: () => verifyGeolocation
36
- });
37
- module.exports = __toCommonJS(browserContext_exports);
38
- var import_fs = __toESM(require("fs"));
39
- var import_path = __toESM(require("path"));
40
- var import_crypto = require("./utils/crypto");
41
- var import_debug = require("./utils/debug");
42
- var import_clock = require("./clock");
43
- var import_debugger = require("./debugger");
44
- var import_dialog = require("./dialog");
45
- var import_fetch = require("./fetch");
46
- var import_fileUtils = require("./utils/fileUtils");
47
- var import_stackTrace = require("../utils/isomorphic/stackTrace");
48
- var import_harRecorder = require("./har/harRecorder");
49
- var import_helper = require("./helper");
50
- var import_instrumentation = require("./instrumentation");
51
- var network = __toESM(require("./network"));
52
- var import_page = require("./page");
53
- var import_page2 = require("./page");
54
- var import_recorderApp = require("./recorder/recorderApp");
55
- var import_selectors = require("./selectors");
56
- var import_tracing = require("./trace/recorder/tracing");
57
- var rawStorageSource = __toESM(require("../generated/storageScriptSource"));
58
- const BrowserContextEvent = {
59
- Console: "console",
60
- Close: "close",
61
- Page: "page",
62
- // Can't use just 'error' due to node.js special treatment of error events.
63
- // @see https://nodejs.org/api/events.html#events_error_events
64
- PageError: "pageerror",
65
- Request: "request",
66
- Response: "response",
67
- RequestFailed: "requestfailed",
68
- RequestFinished: "requestfinished",
69
- RequestAborted: "requestaborted",
70
- RequestFulfilled: "requestfulfilled",
71
- RequestContinued: "requestcontinued",
72
- BeforeClose: "beforeclose",
73
- VideoStarted: "videostarted",
74
- RecorderEvent: "recorderevent"
75
- };
76
- class BrowserContext extends import_instrumentation.SdkObject {
77
- constructor(browser, options, browserContextId) {
78
- super(browser, "browser-context");
79
- this._pageBindings = /* @__PURE__ */ new Map();
80
- this.requestInterceptors = [];
81
- this._closedStatus = "open";
82
- this._permissions = /* @__PURE__ */ new Map();
83
- this._downloads = /* @__PURE__ */ new Set();
84
- this._origins = /* @__PURE__ */ new Set();
85
- this._harRecorders = /* @__PURE__ */ new Map();
86
- this._tempDirs = [];
87
- this._creatingStorageStatePage = false;
88
- this.initScripts = [];
89
- this._routesInFlight = /* @__PURE__ */ new Set();
90
- this._consoleApiExposed = false;
91
- this.attribution.context = this;
92
- this._browser = browser;
93
- this._options = options;
94
- this._browserContextId = browserContextId;
95
- this._isPersistentContext = !browserContextId;
96
- this._closePromise = new Promise((fulfill) => this._closePromiseFulfill = fulfill);
97
- this._selectors = new import_selectors.Selectors(options.selectorEngines || [], options.testIdAttributeName);
98
- this.fetchRequest = new import_fetch.BrowserContextAPIRequestContext(this);
99
- this.tracing = new import_tracing.Tracing(this, browser.options.tracesDir);
100
- this.clock = new import_clock.Clock(this);
101
- this.dialogManager = new import_dialog.DialogManager(this.instrumentation);
102
- }
103
- static {
104
- this.Events = BrowserContextEvent;
105
- }
106
- isPersistentContext() {
107
- return this._isPersistentContext;
108
- }
109
- selectors() {
110
- return this._selectors;
111
- }
112
- async _initialize() {
113
- if (this.attribution.playwright.options.isInternalPlaywright)
114
- return;
115
- this._debugger = new import_debugger.Debugger(this);
116
- if ((0, import_debug.debugMode)() === "inspector")
117
- await import_recorderApp.RecorderApp.show(this, { pauseOnNextStatement: true });
118
- if (this._debugger.isPaused())
119
- import_recorderApp.RecorderApp.showInspectorNoReply(this);
120
- this._debugger.on(import_debugger.Debugger.Events.PausedStateChanged, () => {
121
- if (this._debugger.isPaused())
122
- import_recorderApp.RecorderApp.showInspectorNoReply(this);
123
- });
124
- if ((0, import_debug.debugMode)() === "console")
125
- await this.exposeConsoleApi();
126
- if (this._options.serviceWorkers === "block")
127
- await this.addInitScript(void 0, `
128
- if (navigator.serviceWorker) navigator.serviceWorker.register = async () => { console.warn('Service Worker registration blocked by Playwright'); };
129
- `);
130
- if (this._options.permissions)
131
- await this.grantPermissions(this._options.permissions);
132
- }
133
- debugger() {
134
- return this._debugger;
135
- }
136
- async exposeConsoleApi() {
137
- if (this._consoleApiExposed)
138
- return;
139
- this._consoleApiExposed = true;
140
- await this.extendInjectedScript(`
141
- function installConsoleApi(injectedScript) { injectedScript.consoleApi.install(); }
142
- module.exports = { default: () => installConsoleApi };
143
- `);
144
- }
145
- async _ensureVideosPath() {
146
- if (this._options.recordVideo)
147
- await (0, import_fileUtils.mkdirIfNeeded)(import_path.default.join(this._options.recordVideo.dir, "dummy"));
148
- }
149
- canResetForReuse() {
150
- if (this._closedStatus !== "open")
151
- return false;
152
- return true;
153
- }
154
- static reusableContextHash(params) {
155
- const paramsCopy = { ...params };
156
- if (paramsCopy.selectorEngines?.length === 0)
157
- delete paramsCopy.selectorEngines;
158
- for (const k of Object.keys(paramsCopy)) {
159
- const key = k;
160
- if (paramsCopy[key] === defaultNewContextParamValues[key])
161
- delete paramsCopy[key];
162
- }
163
- for (const key of paramsThatAllowContextReuse)
164
- delete paramsCopy[key];
165
- return JSON.stringify(paramsCopy);
166
- }
167
- async resetForReuse(progress, params) {
168
- await this.tracing.resetForReuse(progress);
169
- if (params) {
170
- for (const key of paramsThatAllowContextReuse)
171
- this._options[key] = params[key];
172
- if (params.testIdAttributeName)
173
- this.selectors().setTestIdAttributeName(params.testIdAttributeName);
174
- }
175
- let page = this.pages()[0];
176
- const otherPages = this.possiblyUninitializedPages().filter((p) => p !== page);
177
- for (const p of otherPages)
178
- await p.close();
179
- if (page && page.hasCrashed()) {
180
- await page.close();
181
- page = void 0;
182
- }
183
- await page?.mainFrame().gotoImpl(progress, "about:blank", {});
184
- await this.clock.uninstall(progress);
185
- await progress.race(this.setUserAgent(this._options.userAgent));
186
- await progress.race(this.doUpdateDefaultEmulatedMedia());
187
- await progress.race(this.doUpdateDefaultViewport());
188
- await this.setStorageState(progress, this._options.storageState, "resetForReuse");
189
- await page?.resetForReuse(progress);
190
- }
191
- _browserClosed() {
192
- for (const page of this.pages())
193
- page._didClose();
194
- this._didCloseInternal();
195
- }
196
- _didCloseInternal() {
197
- if (this._closedStatus === "closed") {
198
- return;
199
- }
200
- this._clientCertificatesProxy?.close().catch(() => {
201
- });
202
- this.tracing.abort();
203
- if (this._isPersistentContext)
204
- this.onClosePersistent();
205
- this._closePromiseFulfill(new Error("Context closed"));
206
- this.emit(BrowserContext.Events.Close);
207
- }
208
- pages() {
209
- return this.possiblyUninitializedPages().filter((page) => page.initializedOrUndefined());
210
- }
211
- async cookies(urls = []) {
212
- if (urls && !Array.isArray(urls))
213
- urls = [urls];
214
- return await this.doGetCookies(urls);
215
- }
216
- async clearCookies(options) {
217
- const currentCookies = await this.cookies();
218
- await this.doClearCookies();
219
- const matches = (cookie, prop, value) => {
220
- if (!value)
221
- return true;
222
- if (value instanceof RegExp) {
223
- value.lastIndex = 0;
224
- return value.test(cookie[prop]);
225
- }
226
- return cookie[prop] === value;
227
- };
228
- const cookiesToReadd = currentCookies.filter((cookie) => {
229
- return !matches(cookie, "name", options.name) || !matches(cookie, "domain", options.domain) || !matches(cookie, "path", options.path);
230
- });
231
- await this.addCookies(cookiesToReadd);
232
- }
233
- setHTTPCredentials(httpCredentials) {
234
- return this.doSetHTTPCredentials(httpCredentials);
235
- }
236
- getBindingClient(name) {
237
- return this._pageBindings.get(name)?.forClient;
238
- }
239
- async exposePlaywrightBindingIfNeeded() {
240
- this._playwrightBindingExposed ??= (async () => {
241
- await this.doExposePlaywrightBinding();
242
- this.bindingsInitScript = import_page2.PageBinding.createInitScript();
243
- this.initScripts.push(this.bindingsInitScript);
244
- await this.doAddInitScript(this.bindingsInitScript);
245
- await this.safeNonStallingEvaluateInAllFrames(this.bindingsInitScript.source, "main");
246
- })();
247
- return await this._playwrightBindingExposed;
248
- }
249
- needsPlaywrightBinding() {
250
- return this._playwrightBindingExposed !== void 0;
251
- }
252
- async exposeBinding(progress, name, needsHandle, playwrightBinding, forClient) {
253
- if (this._pageBindings.has(name))
254
- throw new Error(`Function "${name}" has been already registered`);
255
- for (const page of this.pages()) {
256
- if (page.getBinding(name))
257
- throw new Error(`Function "${name}" has been already registered in one of the pages`);
258
- }
259
- await progress.race(this.exposePlaywrightBindingIfNeeded());
260
- const binding = new import_page2.PageBinding(name, playwrightBinding, needsHandle);
261
- binding.forClient = forClient;
262
- this._pageBindings.set(name, binding);
263
- try {
264
- await progress.race(this.doAddInitScript(binding.initScript));
265
- await progress.race(this.safeNonStallingEvaluateInAllFrames(binding.initScript.source, "main"));
266
- return binding;
267
- } catch (error) {
268
- this._pageBindings.delete(name);
269
- throw error;
270
- }
271
- }
272
- async removeExposedBindings(bindings) {
273
- bindings = bindings.filter((binding) => this._pageBindings.get(binding.name) === binding);
274
- for (const binding of bindings)
275
- this._pageBindings.delete(binding.name);
276
- await this.doRemoveInitScripts(bindings.map((binding) => binding.initScript));
277
- const cleanup = bindings.map((binding) => `{ ${binding.cleanupScript} };
278
- `).join("");
279
- await this.safeNonStallingEvaluateInAllFrames(cleanup, "main");
280
- }
281
- async grantPermissions(permissions, origin) {
282
- let resolvedOrigin = "*";
283
- if (origin) {
284
- const url = new URL(origin);
285
- resolvedOrigin = url.origin;
286
- }
287
- const existing = new Set(this._permissions.get(resolvedOrigin) || []);
288
- permissions.forEach((p) => existing.add(p));
289
- const list = [...existing.values()];
290
- this._permissions.set(resolvedOrigin, list);
291
- await this.doGrantPermissions(resolvedOrigin, list);
292
- }
293
- async clearPermissions() {
294
- this._permissions.clear();
295
- await this.doClearPermissions();
296
- }
297
- async setExtraHTTPHeaders(progress, headers) {
298
- const oldHeaders = this._options.extraHTTPHeaders;
299
- this._options.extraHTTPHeaders = headers;
300
- try {
301
- await progress.race(this.doUpdateExtraHTTPHeaders());
302
- } catch (error) {
303
- this._options.extraHTTPHeaders = oldHeaders;
304
- this.doUpdateExtraHTTPHeaders().catch(() => {
305
- });
306
- throw error;
307
- }
308
- }
309
- async setOffline(progress, offline) {
310
- const oldOffline = this._options.offline;
311
- this._options.offline = offline;
312
- try {
313
- await progress.race(this.doUpdateOffline());
314
- } catch (error) {
315
- this._options.offline = oldOffline;
316
- this.doUpdateOffline().catch(() => {
317
- });
318
- throw error;
319
- }
320
- }
321
- async _loadDefaultContextAsIs(progress) {
322
- if (!this.possiblyUninitializedPages().length) {
323
- const waitForEvent = import_helper.helper.waitForEvent(progress, this, BrowserContext.Events.Page);
324
- await Promise.race([waitForEvent.promise, this._closePromise]);
325
- }
326
- const page = this.possiblyUninitializedPages()[0];
327
- if (!page)
328
- return;
329
- const pageOrError = await progress.race(page.waitForInitializedOrError());
330
- if (pageOrError instanceof Error)
331
- throw pageOrError;
332
- await page.mainFrame().waitForLoadState(progress, "load");
333
- return page;
334
- }
335
- async _loadDefaultContext(progress) {
336
- const defaultPage = await this._loadDefaultContextAsIs(progress);
337
- if (!defaultPage)
338
- return;
339
- const browserName = this._browser.options.name;
340
- if (this._options.isMobile && browserName === "chromium" || this._options.locale && browserName === "webkit") {
341
- await this.newPage(progress);
342
- await defaultPage.close();
343
- }
344
- }
345
- _authenticateProxyViaHeader() {
346
- const proxy = this._options.proxy || this._browser.options.proxy || { username: void 0, password: void 0 };
347
- const { username, password } = proxy;
348
- if (username) {
349
- this._options.httpCredentials = { username, password };
350
- const token = Buffer.from(`${username}:${password}`).toString("base64");
351
- this._options.extraHTTPHeaders = network.mergeHeaders([
352
- this._options.extraHTTPHeaders,
353
- network.singleHeader("Proxy-Authorization", `Basic ${token}`)
354
- ]);
355
- }
356
- }
357
- _authenticateProxyViaCredentials() {
358
- const proxy = this._options.proxy || this._browser.options.proxy;
359
- if (!proxy)
360
- return;
361
- const { username, password } = proxy;
362
- if (username)
363
- this._options.httpCredentials = { username, password: password || "" };
364
- }
365
- async addInitScript(progress, source) {
366
- const initScript = new import_page.InitScript(source);
367
- this.initScripts.push(initScript);
368
- try {
369
- const promise = this.doAddInitScript(initScript);
370
- if (progress)
371
- await progress.race(promise);
372
- else
373
- await promise;
374
- return initScript;
375
- } catch (error) {
376
- this.removeInitScripts([initScript]).catch(() => {
377
- });
378
- throw error;
379
- }
380
- }
381
- async removeInitScripts(initScripts) {
382
- const set = new Set(initScripts);
383
- this.initScripts = this.initScripts.filter((script) => !set.has(script));
384
- await this.doRemoveInitScripts(initScripts);
385
- }
386
- async addRequestInterceptor(progress, handler) {
387
- this.requestInterceptors.push(handler);
388
- await this.doUpdateRequestInterception();
389
- }
390
- async removeRequestInterceptor(handler) {
391
- const index = this.requestInterceptors.indexOf(handler);
392
- if (index === -1)
393
- return;
394
- this.requestInterceptors.splice(index, 1);
395
- await this.notifyRoutesInFlightAboutRemovedHandler(handler);
396
- await this.doUpdateRequestInterception();
397
- }
398
- isClosingOrClosed() {
399
- return this._closedStatus !== "open";
400
- }
401
- async _deleteAllDownloads() {
402
- await Promise.all(Array.from(this._downloads).map((download) => download.artifact.deleteOnContextClose()));
403
- }
404
- async _deleteAllTempDirs() {
405
- await Promise.all(this._tempDirs.map(async (dir) => await import_fs.default.promises.unlink(dir).catch((e) => {
406
- })));
407
- }
408
- setCustomCloseHandler(handler) {
409
- this._customCloseHandler = handler;
410
- }
411
- async close(options) {
412
- if (this._closedStatus === "open") {
413
- if (options.reason)
414
- this._closeReason = options.reason;
415
- this.emit(BrowserContext.Events.BeforeClose);
416
- this._closedStatus = "closing";
417
- for (const harRecorder of this._harRecorders.values())
418
- await harRecorder.flush();
419
- await this.tracing.flush();
420
- const promises = [];
421
- for (const { context, artifact } of this._browser._idToVideo.values()) {
422
- if (context === this)
423
- promises.push(artifact.finishedPromise());
424
- }
425
- if (this._customCloseHandler) {
426
- await this._customCloseHandler();
427
- } else {
428
- await this.doClose(options.reason);
429
- }
430
- promises.push(this._deleteAllDownloads());
431
- promises.push(this._deleteAllTempDirs());
432
- await Promise.all(promises);
433
- if (!this._customCloseHandler)
434
- this._didCloseInternal();
435
- }
436
- await this._closePromise;
437
- }
438
- async newPage(progress, forStorageState) {
439
- let page;
440
- try {
441
- this._creatingStorageStatePage = !!forStorageState;
442
- page = await progress.race(this.doCreateNewPage());
443
- const pageOrError = await progress.race(page.waitForInitializedOrError());
444
- if (pageOrError instanceof import_page2.Page) {
445
- if (pageOrError.isClosed())
446
- throw new Error("Page has been closed.");
447
- return pageOrError;
448
- }
449
- throw pageOrError;
450
- } catch (error) {
451
- await page?.close({ reason: "Failed to create page" }).catch(() => {
452
- });
453
- throw error;
454
- } finally {
455
- this._creatingStorageStatePage = false;
456
- }
457
- }
458
- addVisitedOrigin(origin) {
459
- this._origins.add(origin);
460
- }
461
- async storageState(progress, indexedDB = false) {
462
- const result = {
463
- cookies: await this.cookies(),
464
- origins: []
465
- };
466
- const originsToSave = new Set(this._origins);
467
- const collectScript = `(() => {
468
- const module = {};
469
- ${rawStorageSource.source}
470
- const script = new (module.exports.StorageScript())(${this._browser.options.name === "firefox"});
471
- return script.collect(${indexedDB});
472
- })()`;
473
- for (const page of this.pages()) {
474
- const origin = page.mainFrame().origin();
475
- if (!origin || !originsToSave.has(origin))
476
- continue;
477
- try {
478
- const storage = await page.mainFrame().nonStallingEvaluateInExistingContext(collectScript, "utility");
479
- if (storage.localStorage.length || storage.indexedDB?.length)
480
- result.origins.push({ origin, localStorage: storage.localStorage, indexedDB: storage.indexedDB });
481
- originsToSave.delete(origin);
482
- } catch {
483
- }
484
- }
485
- if (originsToSave.size) {
486
- const page = await this.newPage(
487
- progress,
488
- true
489
- /* forStorageState */
490
- );
491
- try {
492
- await page.addRequestInterceptor(progress, (route) => {
493
- route.fulfill({ body: "<html></html>" }).catch(() => {
494
- });
495
- }, "prepend");
496
- for (const origin of originsToSave) {
497
- const frame = page.mainFrame();
498
- await frame.gotoImpl(progress, origin, {});
499
- const storage = await progress.race(frame.evaluateExpression(collectScript, { world: "utility" }));
500
- if (storage.localStorage.length || storage.indexedDB?.length)
501
- result.origins.push({ origin, localStorage: storage.localStorage, indexedDB: storage.indexedDB });
502
- }
503
- } finally {
504
- await page.close();
505
- }
506
- }
507
- return result;
508
- }
509
- isCreatingStorageStatePage() {
510
- return this._creatingStorageStatePage;
511
- }
512
- async setStorageState(progress, state, mode) {
513
- let page;
514
- let interceptor;
515
- try {
516
- if (mode !== "initial") {
517
- await progress.race(this.clearCache());
518
- await progress.race(this.doClearCookies());
519
- }
520
- if (state?.cookies)
521
- await progress.race(this.addCookies(state.cookies));
522
- const newOrigins = new Map(state?.origins?.map((p) => [p.origin, p]) || []);
523
- const allOrigins = /* @__PURE__ */ new Set([...this._origins, ...newOrigins.keys()]);
524
- if (allOrigins.size) {
525
- if (mode === "resetForReuse")
526
- page = this.pages()[0];
527
- if (!page)
528
- page = await this.newPage(
529
- progress,
530
- mode !== "resetForReuse"
531
- /* forStorageState */
532
- );
533
- interceptor = (route) => {
534
- route.fulfill({ body: "<html></html>" }).catch(() => {
535
- });
536
- };
537
- await page.addRequestInterceptor(progress, interceptor, "prepend");
538
- for (const origin of allOrigins) {
539
- const frame = page.mainFrame();
540
- await frame.gotoImpl(progress, origin, {});
541
- const restoreScript = `(() => {
542
- const module = {};
543
- ${rawStorageSource.source}
544
- const script = new (module.exports.StorageScript())(${this._browser.options.name === "firefox"});
545
- return script.restore(${JSON.stringify(newOrigins.get(origin))});
546
- })()`;
547
- await progress.race(frame.evaluateExpression(restoreScript, { world: "utility" }));
548
- }
549
- }
550
- this._origins = /* @__PURE__ */ new Set([...newOrigins.keys()]);
551
- } catch (error) {
552
- (0, import_stackTrace.rewriteErrorMessage)(error, `Error setting storage state:
553
- ` + error.message);
554
- throw error;
555
- } finally {
556
- if (mode !== "resetForReuse")
557
- await page?.close();
558
- else if (interceptor)
559
- await page?.removeRequestInterceptor(interceptor);
560
- }
561
- }
562
- async extendInjectedScript(source, arg) {
563
- const installInFrame = (frame) => frame.extendInjectedScript(source, arg).catch(() => {
564
- });
565
- const installInPage = (page) => {
566
- page.on(import_page2.Page.Events.InternalFrameNavigatedToNewDocument, installInFrame);
567
- return Promise.all(page.frames().map(installInFrame));
568
- };
569
- this.on(BrowserContext.Events.Page, installInPage);
570
- return Promise.all(this.pages().map(installInPage));
571
- }
572
- async safeNonStallingEvaluateInAllFrames(expression, world, options = {}) {
573
- await Promise.all(this.pages().map((page) => page.safeNonStallingEvaluateInAllFrames(expression, world, options)));
574
- }
575
- harStart(page, options) {
576
- const harId = (0, import_crypto.createGuid)();
577
- this._harRecorders.set(harId, new import_harRecorder.HarRecorder(this, page, options));
578
- return harId;
579
- }
580
- async harExport(harId) {
581
- const recorder = this._harRecorders.get(harId || "");
582
- return recorder.export();
583
- }
584
- addRouteInFlight(route) {
585
- this._routesInFlight.add(route);
586
- }
587
- removeRouteInFlight(route) {
588
- this._routesInFlight.delete(route);
589
- }
590
- async notifyRoutesInFlightAboutRemovedHandler(handler) {
591
- await Promise.all([...this._routesInFlight].map((route) => route.removeHandler(handler)));
592
- }
593
- }
594
- function validateBrowserContextOptions(options, browserOptions) {
595
- if (options.noDefaultViewport && options.deviceScaleFactor !== void 0)
596
- throw new Error(`"deviceScaleFactor" option is not supported with null "viewport"`);
597
- if (options.noDefaultViewport && !!options.isMobile)
598
- throw new Error(`"isMobile" option is not supported with null "viewport"`);
599
- if (options.acceptDownloads === void 0 && browserOptions.name !== "electron")
600
- options.acceptDownloads = "accept";
601
- else if (options.acceptDownloads === void 0 && browserOptions.name === "electron")
602
- options.acceptDownloads = "internal-browser-default";
603
- if (!options.viewport && !options.noDefaultViewport)
604
- options.viewport = { width: 1280, height: 720 };
605
- if (options.recordVideo) {
606
- if (!options.recordVideo.size) {
607
- if (options.noDefaultViewport) {
608
- options.recordVideo.size = { width: 800, height: 600 };
609
- } else {
610
- const size = options.viewport;
611
- const scale = Math.min(1, 800 / Math.max(size.width, size.height));
612
- options.recordVideo.size = {
613
- width: Math.floor(size.width * scale),
614
- height: Math.floor(size.height * scale)
615
- };
616
- }
617
- }
618
- options.recordVideo.size.width &= ~1;
619
- options.recordVideo.size.height &= ~1;
620
- }
621
- if (options.proxy)
622
- options.proxy = normalizeProxySettings(options.proxy);
623
- verifyGeolocation(options.geolocation);
624
- }
625
- function verifyGeolocation(geolocation) {
626
- if (!geolocation)
627
- return;
628
- geolocation.accuracy = geolocation.accuracy || 0;
629
- const { longitude, latitude, accuracy } = geolocation;
630
- if (longitude < -180 || longitude > 180)
631
- throw new Error(`geolocation.longitude: precondition -180 <= LONGITUDE <= 180 failed.`);
632
- if (latitude < -90 || latitude > 90)
633
- throw new Error(`geolocation.latitude: precondition -90 <= LATITUDE <= 90 failed.`);
634
- if (accuracy < 0)
635
- throw new Error(`geolocation.accuracy: precondition 0 <= ACCURACY failed.`);
636
- }
637
- function verifyClientCertificates(clientCertificates) {
638
- if (!clientCertificates)
639
- return;
640
- for (const cert of clientCertificates) {
641
- if (!cert.origin)
642
- throw new Error(`clientCertificates.origin is required`);
643
- if (!cert.cert && !cert.key && !cert.passphrase && !cert.pfx)
644
- throw new Error("None of cert, key, passphrase or pfx is specified");
645
- if (cert.cert && !cert.key)
646
- throw new Error("cert is specified without key");
647
- if (!cert.cert && cert.key)
648
- throw new Error("key is specified without cert");
649
- if (cert.pfx && (cert.cert || cert.key))
650
- throw new Error("pfx is specified together with cert, key or passphrase");
651
- }
652
- }
653
- function normalizeProxySettings(proxy) {
654
- let { server, bypass } = proxy;
655
- let url;
656
- try {
657
- url = new URL(server);
658
- if (!url.host || !url.protocol)
659
- url = new URL("http://" + server);
660
- } catch (e) {
661
- url = new URL("http://" + server);
662
- }
663
- if (url.protocol === "socks4:" && (proxy.username || proxy.password))
664
- throw new Error(`Socks4 proxy protocol does not support authentication`);
665
- if (url.protocol === "socks5:" && (proxy.username || proxy.password))
666
- throw new Error(`Browser does not support socks5 proxy authentication`);
667
- server = url.protocol + "//" + url.host;
668
- if (bypass)
669
- bypass = bypass.split(",").map((t) => t.trim()).join(",");
670
- return { ...proxy, server, bypass };
671
- }
672
- const paramsThatAllowContextReuse = [
673
- "colorScheme",
674
- "forcedColors",
675
- "reducedMotion",
676
- "contrast",
677
- "screen",
678
- "userAgent",
679
- "viewport",
680
- "testIdAttributeName"
681
- ];
682
- const defaultNewContextParamValues = {
683
- noDefaultViewport: false,
684
- ignoreHTTPSErrors: false,
685
- javaScriptEnabled: true,
686
- bypassCSP: false,
687
- offline: false,
688
- isMobile: false,
689
- hasTouch: false,
690
- acceptDownloads: "accept",
691
- strictSelectors: false,
692
- serviceWorkers: "allow",
693
- locale: "en-US"
694
- };
695
- // Annotate the CommonJS export names for ESM import in node:
696
- 0 && (module.exports = {
697
- BrowserContext,
698
- normalizeProxySettings,
699
- validateBrowserContextOptions,
700
- verifyClientCertificates,
701
- verifyGeolocation
702
- });
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var browserContext_exports = {};
30
+ __export(browserContext_exports, {
31
+ BrowserContext: () => BrowserContext,
32
+ calculateUserAgentEmulation: () => calculateUserAgentEmulation,
33
+ normalizeProxySettings: () => normalizeProxySettings,
34
+ validateBrowserContextOptions: () => validateBrowserContextOptions,
35
+ verifyClientCertificates: () => verifyClientCertificates,
36
+ verifyGeolocation: () => verifyGeolocation
37
+ });
38
+ module.exports = __toCommonJS(browserContext_exports);
39
+ var import_fs = __toESM(require("fs"));
40
+ var import_crypto = require("./utils/crypto");
41
+ var import_debug = require("./utils/debug");
42
+ var import_clock = require("./clock");
43
+ var import_debugger = require("./debugger");
44
+ var import_dialog = require("./dialog");
45
+ var import_fetch = require("./fetch");
46
+ var import_stackTrace = require("../utils/isomorphic/stackTrace");
47
+ var import_harRecorder = require("./har/harRecorder");
48
+ var import_helper = require("./helper");
49
+ var import_instrumentation = require("./instrumentation");
50
+ var network = __toESM(require("./network"));
51
+ var import_page = require("./page");
52
+ var import_page2 = require("./page");
53
+ var import_recorderApp = require("./recorder/recorderApp");
54
+ var import_selectors = require("./selectors");
55
+ var import_tracing = require("./trace/recorder/tracing");
56
+ var rawStorageSource = __toESM(require("../generated/storageScriptSource"));
57
+ const BrowserContextEvent = {
58
+ Console: "console",
59
+ Close: "close",
60
+ Page: "page",
61
+ // Can't use just 'error' due to node.js special treatment of error events.
62
+ // @see https://nodejs.org/api/events.html#events_error_events
63
+ PageError: "pageerror",
64
+ Request: "request",
65
+ Response: "response",
66
+ RequestFailed: "requestfailed",
67
+ RequestFinished: "requestfinished",
68
+ RequestAborted: "requestaborted",
69
+ RequestFulfilled: "requestfulfilled",
70
+ RequestContinued: "requestcontinued",
71
+ BeforeClose: "beforeclose",
72
+ RecorderEvent: "recorderevent",
73
+ PageClosed: "pageclosed",
74
+ InternalFrameNavigatedToNewDocument: "internalframenavigatedtonewdocument"
75
+ };
76
+ class BrowserContext extends import_instrumentation.SdkObject {
77
+ constructor(browser, options, browserContextId) {
78
+ super(browser, "browser-context");
79
+ this._pageBindings = /* @__PURE__ */ new Map();
80
+ this.requestInterceptors = [];
81
+ this._closedStatus = "open";
82
+ this._permissions = /* @__PURE__ */ new Map();
83
+ this._downloads = /* @__PURE__ */ new Set();
84
+ this._origins = /* @__PURE__ */ new Set();
85
+ this._harRecorders = /* @__PURE__ */ new Map();
86
+ this._tempDirs = [];
87
+ this._creatingStorageStatePage = false;
88
+ this.initScripts = [];
89
+ this._routesInFlight = /* @__PURE__ */ new Set();
90
+ this._consoleApiExposed = false;
91
+ this.attribution.context = this;
92
+ this._browser = browser;
93
+ this._options = options;
94
+ this._browserContextId = browserContextId;
95
+ this._isPersistentContext = !browserContextId;
96
+ this._closePromise = new Promise((fulfill) => this._closePromiseFulfill = fulfill);
97
+ this._selectors = new import_selectors.Selectors(options.selectorEngines || [], options.testIdAttributeName);
98
+ this.fetchRequest = new import_fetch.BrowserContextAPIRequestContext(this);
99
+ this.tracing = new import_tracing.Tracing(this, browser.options.tracesDir);
100
+ this.clock = new import_clock.Clock(this);
101
+ this.dialogManager = new import_dialog.DialogManager(this.instrumentation);
102
+ }
103
+ static {
104
+ this.Events = BrowserContextEvent;
105
+ }
106
+ isPersistentContext() {
107
+ return this._isPersistentContext;
108
+ }
109
+ selectors() {
110
+ return this._selectors;
111
+ }
112
+ async _initialize() {
113
+ if (this.attribution.playwright.options.isInternalPlaywright)
114
+ return;
115
+ this._debugger = new import_debugger.Debugger(this);
116
+ const shouldEnableDebugger = !this.attribution.playwright.options.isServer && ((0, import_debug.isUnderTest)() || !!this._browser.options.headful);
117
+ if (shouldEnableDebugger) {
118
+ this._debugger.setPauseAt();
119
+ this._debugger.on(import_debugger.Debugger.Events.PausedStateChanged, () => {
120
+ if (this._debugger.isPaused())
121
+ import_recorderApp.RecorderApp.showInspectorNoReply(this);
122
+ });
123
+ }
124
+ if ((0, import_debug.debugMode)() === "inspector") {
125
+ this._debugger.setPauseAt({ next: true });
126
+ await import_recorderApp.RecorderApp.show(this, { pauseOnNextStatement: true });
127
+ }
128
+ if ((0, import_debug.debugMode)() === "console")
129
+ await this.exposeConsoleApi();
130
+ if (this._options.serviceWorkers === "block")
131
+ await this.addInitScript(`
132
+ if (navigator.serviceWorker) navigator.serviceWorker.register = async () => { console.warn('Service Worker registration blocked by Playwright'); };
133
+ `);
134
+ if (this._options.permissions)
135
+ await this.grantPermissions(this._options.permissions);
136
+ }
137
+ debugger() {
138
+ return this._debugger;
139
+ }
140
+ async exposeConsoleApi() {
141
+ if (this._consoleApiExposed)
142
+ return;
143
+ this._consoleApiExposed = true;
144
+ await this.extendInjectedScript(`
145
+ function installConsoleApi(injectedScript) { injectedScript.consoleApi.install(); }
146
+ module.exports = { default: () => installConsoleApi };
147
+ `);
148
+ }
149
+ canResetForReuse() {
150
+ if (this._closedStatus !== "open")
151
+ return false;
152
+ return true;
153
+ }
154
+ static reusableContextHash(params) {
155
+ const paramsCopy = { ...params };
156
+ if (paramsCopy.selectorEngines?.length === 0)
157
+ delete paramsCopy.selectorEngines;
158
+ for (const k of Object.keys(paramsCopy)) {
159
+ const key = k;
160
+ if (paramsCopy[key] === defaultNewContextParamValues[key])
161
+ delete paramsCopy[key];
162
+ }
163
+ for (const key of paramsThatAllowContextReuse)
164
+ delete paramsCopy[key];
165
+ return JSON.stringify(paramsCopy);
166
+ }
167
+ async resetForReuse(progress, params) {
168
+ await this.tracing.resetForReuse(progress);
169
+ if (params) {
170
+ for (const key of paramsThatAllowContextReuse)
171
+ this._options[key] = params[key];
172
+ if (params.testIdAttributeName)
173
+ this.selectors().setTestIdAttributeName(params.testIdAttributeName);
174
+ }
175
+ let page = this.pages()[0];
176
+ const otherPages = this.possiblyUninitializedPages().filter((p) => p !== page);
177
+ for (const p of otherPages)
178
+ await p.close();
179
+ if (page && page.hasCrashed()) {
180
+ await page.close();
181
+ page = void 0;
182
+ }
183
+ await page?.mainFrame().gotoImpl(progress, "about:blank", {});
184
+ await this.clock.uninstall(progress);
185
+ await progress.race(this.setUserAgent(this._options.userAgent));
186
+ await progress.race(this.doUpdateDefaultEmulatedMedia());
187
+ await progress.race(this.doUpdateDefaultViewport());
188
+ await this.setStorageState(progress, this._options.storageState, "resetForReuse");
189
+ await page?.resetForReuse(progress);
190
+ }
191
+ _browserClosed() {
192
+ for (const page of this.pages())
193
+ page._didClose();
194
+ this._didCloseInternal();
195
+ }
196
+ _didCloseInternal() {
197
+ if (this._closedStatus === "closed") {
198
+ return;
199
+ }
200
+ this._clientCertificatesProxy?.close().catch(() => {
201
+ });
202
+ this.tracing.abort();
203
+ if (this._isPersistentContext)
204
+ this.onClosePersistent();
205
+ this._closePromiseFulfill(new Error("Context closed"));
206
+ this.emit(BrowserContext.Events.Close);
207
+ }
208
+ pages() {
209
+ return this.possiblyUninitializedPages().filter((page) => page.initializedOrUndefined());
210
+ }
211
+ async cookies(urls = []) {
212
+ if (urls && !Array.isArray(urls))
213
+ urls = [urls];
214
+ return await this.doGetCookies(urls);
215
+ }
216
+ async clearCookies(options) {
217
+ const currentCookies = await this.cookies();
218
+ await this.doClearCookies();
219
+ const matches = (cookie, prop, value) => {
220
+ if (!value)
221
+ return true;
222
+ if (value instanceof RegExp) {
223
+ value.lastIndex = 0;
224
+ return value.test(cookie[prop]);
225
+ }
226
+ return cookie[prop] === value;
227
+ };
228
+ const cookiesToReadd = currentCookies.filter((cookie) => {
229
+ return !matches(cookie, "name", options.name) || !matches(cookie, "domain", options.domain) || !matches(cookie, "path", options.path);
230
+ });
231
+ await this.addCookies(cookiesToReadd);
232
+ }
233
+ setHTTPCredentials(httpCredentials) {
234
+ return this.doSetHTTPCredentials(httpCredentials);
235
+ }
236
+ getBindingClient(name) {
237
+ return this._pageBindings.get(name)?.forClient;
238
+ }
239
+ async exposePlaywrightBindingIfNeeded() {
240
+ this._playwrightBindingExposed ??= (async () => {
241
+ await this.doExposePlaywrightBinding();
242
+ this.bindingsInitScript = import_page2.PageBinding.createInitScript(this);
243
+ this.initScripts.push(this.bindingsInitScript);
244
+ await this.doAddInitScript(this.bindingsInitScript);
245
+ await this.safeNonStallingEvaluateInAllFrames(this.bindingsInitScript.source, "main");
246
+ })();
247
+ return await this._playwrightBindingExposed;
248
+ }
249
+ needsPlaywrightBinding() {
250
+ return this._playwrightBindingExposed !== void 0;
251
+ }
252
+ async exposeBinding(progress, name, needsHandle, playwrightBinding, forClient) {
253
+ if (this._pageBindings.has(name))
254
+ throw new Error(`Function "${name}" has been already registered`);
255
+ for (const page of this.pages()) {
256
+ if (page.getBinding(name))
257
+ throw new Error(`Function "${name}" has been already registered in one of the pages`);
258
+ }
259
+ await progress.race(this.exposePlaywrightBindingIfNeeded());
260
+ const binding = new import_page2.PageBinding(this, name, playwrightBinding, needsHandle);
261
+ binding.forClient = forClient;
262
+ this._pageBindings.set(name, binding);
263
+ try {
264
+ await progress.race(this.doAddInitScript(binding.initScript));
265
+ await progress.race(this.safeNonStallingEvaluateInAllFrames(binding.initScript.source, "main"));
266
+ return binding;
267
+ } catch (error) {
268
+ this._pageBindings.delete(name);
269
+ throw error;
270
+ }
271
+ }
272
+ async removeExposedBinding(binding) {
273
+ if (this._pageBindings.get(binding.name) !== binding)
274
+ return;
275
+ this._pageBindings.delete(binding.name);
276
+ await this.doRemoveInitScripts([binding.initScript]);
277
+ const cleanup = `{ ${binding.cleanupScript} };`;
278
+ await this.safeNonStallingEvaluateInAllFrames(cleanup, "main");
279
+ }
280
+ async grantPermissions(permissions, origin) {
281
+ let resolvedOrigin = "*";
282
+ if (origin) {
283
+ const url = new URL(origin);
284
+ resolvedOrigin = url.origin;
285
+ }
286
+ const existing = new Set(this._permissions.get(resolvedOrigin) || []);
287
+ permissions.forEach((p) => existing.add(p));
288
+ const list = [...existing.values()];
289
+ this._permissions.set(resolvedOrigin, list);
290
+ await this.doGrantPermissions(resolvedOrigin, list);
291
+ }
292
+ async clearPermissions() {
293
+ this._permissions.clear();
294
+ await this.doClearPermissions();
295
+ }
296
+ async setExtraHTTPHeaders(progress, headers) {
297
+ const oldHeaders = this._options.extraHTTPHeaders;
298
+ this._options.extraHTTPHeaders = headers;
299
+ try {
300
+ await progress.race(this.doUpdateExtraHTTPHeaders());
301
+ } catch (error) {
302
+ this._options.extraHTTPHeaders = oldHeaders;
303
+ this.doUpdateExtraHTTPHeaders().catch(() => {
304
+ });
305
+ throw error;
306
+ }
307
+ }
308
+ async setOffline(progress, offline) {
309
+ const oldOffline = this._options.offline;
310
+ this._options.offline = offline;
311
+ try {
312
+ await progress.race(this.doUpdateOffline());
313
+ } catch (error) {
314
+ this._options.offline = oldOffline;
315
+ this.doUpdateOffline().catch(() => {
316
+ });
317
+ throw error;
318
+ }
319
+ }
320
+ async _loadDefaultContextAsIs(progress) {
321
+ if (!this.possiblyUninitializedPages().length) {
322
+ const waitForEvent = import_helper.helper.waitForEvent(progress, this, BrowserContext.Events.Page);
323
+ await Promise.race([waitForEvent.promise, this._closePromise]);
324
+ }
325
+ const page = this.possiblyUninitializedPages()[0];
326
+ if (!page)
327
+ return;
328
+ const pageOrError = await progress.race(page.waitForInitializedOrError());
329
+ if (pageOrError instanceof Error)
330
+ throw pageOrError;
331
+ await page.mainFrame().waitForLoadState(progress, "load");
332
+ return page;
333
+ }
334
+ async _loadDefaultContext(progress) {
335
+ const defaultPage = await this._loadDefaultContextAsIs(progress);
336
+ if (!defaultPage)
337
+ return;
338
+ const browserName = this._browser.options.name;
339
+ if (this._options.isMobile && browserName === "chromium" || this._options.locale && browserName === "webkit") {
340
+ await this.newPage(progress);
341
+ await defaultPage.close();
342
+ }
343
+ }
344
+ _authenticateProxyViaHeader() {
345
+ const proxy = this._options.proxy || this._browser.options.proxy || { username: void 0, password: void 0 };
346
+ const { username, password } = proxy;
347
+ if (username) {
348
+ this._options.httpCredentials = { username, password };
349
+ const token = Buffer.from(`${username}:${password}`).toString("base64");
350
+ this._options.extraHTTPHeaders = network.mergeHeaders([
351
+ this._options.extraHTTPHeaders,
352
+ network.singleHeader("Proxy-Authorization", `Basic ${token}`)
353
+ ]);
354
+ }
355
+ }
356
+ _authenticateProxyViaCredentials() {
357
+ const proxy = this._options.proxy || this._browser.options.proxy;
358
+ if (!proxy)
359
+ return;
360
+ const { username, password } = proxy;
361
+ if (username)
362
+ this._options.httpCredentials = { username, password: password || "" };
363
+ }
364
+ async addInitScript(source) {
365
+ const initScript = new import_page.InitScript(this, source);
366
+ this.initScripts.push(initScript);
367
+ try {
368
+ await this.doAddInitScript(initScript);
369
+ return initScript;
370
+ } catch (error) {
371
+ initScript.dispose().catch(() => {
372
+ });
373
+ throw error;
374
+ }
375
+ }
376
+ async removeInitScript(initScript) {
377
+ this.initScripts = this.initScripts.filter((script) => initScript !== script);
378
+ await this.doRemoveInitScripts([initScript]);
379
+ }
380
+ async addRequestInterceptor(progress, handler) {
381
+ this.requestInterceptors.push(handler);
382
+ await this.doUpdateRequestInterception();
383
+ }
384
+ async removeRequestInterceptor(handler) {
385
+ const index = this.requestInterceptors.indexOf(handler);
386
+ if (index === -1)
387
+ return;
388
+ this.requestInterceptors.splice(index, 1);
389
+ await this.notifyRoutesInFlightAboutRemovedHandler(handler);
390
+ await this.doUpdateRequestInterception();
391
+ }
392
+ isClosingOrClosed() {
393
+ return this._closedStatus !== "open";
394
+ }
395
+ async _deleteAllDownloads() {
396
+ await Promise.all(Array.from(this._downloads).map((download) => download.artifact.deleteOnContextClose()));
397
+ }
398
+ async _deleteAllTempDirs() {
399
+ await Promise.all(this._tempDirs.map(async (dir) => await import_fs.default.promises.unlink(dir).catch((e) => {
400
+ })));
401
+ }
402
+ setCustomCloseHandler(handler) {
403
+ this._customCloseHandler = handler;
404
+ }
405
+ async close(options) {
406
+ if (this._closedStatus === "open") {
407
+ if (options.reason)
408
+ this._closeReason = options.reason;
409
+ this.emit(BrowserContext.Events.BeforeClose);
410
+ this._closedStatus = "closing";
411
+ for (const harRecorder of this._harRecorders.values())
412
+ await harRecorder.flush();
413
+ await this.tracing.flush();
414
+ await Promise.all(this.pages().map((page) => page.screencast.handlePageOrContextClose()));
415
+ if (this._customCloseHandler) {
416
+ await this._customCloseHandler();
417
+ } else {
418
+ await this.doClose(options.reason);
419
+ }
420
+ const promises = [];
421
+ promises.push(this._deleteAllDownloads());
422
+ promises.push(this._deleteAllTempDirs());
423
+ await Promise.all(promises);
424
+ if (!this._customCloseHandler)
425
+ this._didCloseInternal();
426
+ }
427
+ await this._closePromise;
428
+ }
429
+ async newPage(progress, forStorageState) {
430
+ let page;
431
+ try {
432
+ this._creatingStorageStatePage = !!forStorageState;
433
+ page = await progress.race(this.doCreateNewPage());
434
+ const pageOrError = await progress.race(page.waitForInitializedOrError());
435
+ if (pageOrError instanceof import_page2.Page) {
436
+ if (pageOrError.isClosed())
437
+ throw new Error("Page has been closed.");
438
+ return pageOrError;
439
+ }
440
+ throw pageOrError;
441
+ } catch (error) {
442
+ await page?.close({ reason: "Failed to create page" }).catch(() => {
443
+ });
444
+ throw error;
445
+ } finally {
446
+ this._creatingStorageStatePage = false;
447
+ }
448
+ }
449
+ addVisitedOrigin(origin) {
450
+ this._origins.add(origin);
451
+ }
452
+ async storageState(progress, indexedDB = false) {
453
+ const result = {
454
+ cookies: await this.cookies(),
455
+ origins: []
456
+ };
457
+ const originsToSave = new Set(this._origins);
458
+ const collectScript = `(() => {
459
+ const module = {};
460
+ ${rawStorageSource.source}
461
+ const script = new (module.exports.StorageScript())(${this._browser.options.name === "firefox"});
462
+ return script.collect(${indexedDB});
463
+ })()`;
464
+ for (const page of this.pages()) {
465
+ const origin = page.mainFrame().origin();
466
+ if (!origin || !originsToSave.has(origin))
467
+ continue;
468
+ try {
469
+ const storage = await page.mainFrame().nonStallingEvaluateInExistingContext(collectScript, "utility");
470
+ if (storage.localStorage.length || storage.indexedDB?.length)
471
+ result.origins.push({ origin, localStorage: storage.localStorage, indexedDB: storage.indexedDB });
472
+ originsToSave.delete(origin);
473
+ } catch {
474
+ }
475
+ }
476
+ if (originsToSave.size) {
477
+ const page = await this.newPage(
478
+ progress,
479
+ true
480
+ /* forStorageState */
481
+ );
482
+ try {
483
+ await page.addRequestInterceptor(progress, (route) => {
484
+ route.fulfill({ body: "<html></html>" }).catch(() => {
485
+ });
486
+ }, "prepend");
487
+ for (const origin of originsToSave) {
488
+ const frame = page.mainFrame();
489
+ await frame.gotoImpl(progress, origin, {});
490
+ const storage = await progress.race(frame.evaluateExpression(collectScript, { world: "utility" }));
491
+ if (storage.localStorage.length || storage.indexedDB?.length)
492
+ result.origins.push({ origin, localStorage: storage.localStorage, indexedDB: storage.indexedDB });
493
+ }
494
+ } finally {
495
+ await page.close();
496
+ }
497
+ }
498
+ return result;
499
+ }
500
+ isCreatingStorageStatePage() {
501
+ return this._creatingStorageStatePage;
502
+ }
503
+ async setStorageState(progress, state, mode) {
504
+ let page;
505
+ let interceptor;
506
+ try {
507
+ if (mode !== "initial") {
508
+ await progress.race(this.clearCache());
509
+ await progress.race(this.doClearCookies());
510
+ }
511
+ if (state?.cookies)
512
+ await progress.race(this.addCookies(state.cookies));
513
+ const newOrigins = new Map(state?.origins?.map((p) => [p.origin, p]) || []);
514
+ const allOrigins = /* @__PURE__ */ new Set([...this._origins, ...newOrigins.keys()]);
515
+ if (allOrigins.size) {
516
+ if (mode === "resetForReuse")
517
+ page = this.pages()[0];
518
+ if (!page)
519
+ page = await this.newPage(
520
+ progress,
521
+ mode !== "resetForReuse"
522
+ /* forStorageState */
523
+ );
524
+ interceptor = (route) => {
525
+ route.fulfill({ body: "<html></html>" }).catch(() => {
526
+ });
527
+ };
528
+ await page.addRequestInterceptor(progress, interceptor, "prepend");
529
+ for (const origin of allOrigins) {
530
+ const frame = page.mainFrame();
531
+ await frame.gotoImpl(progress, origin, {});
532
+ const restoreScript = `(() => {
533
+ const module = {};
534
+ ${rawStorageSource.source}
535
+ const script = new (module.exports.StorageScript())(${this._browser.options.name === "firefox"});
536
+ return script.restore(${JSON.stringify(newOrigins.get(origin))});
537
+ })()`;
538
+ await progress.race(frame.evaluateExpression(restoreScript, { world: "utility" }));
539
+ }
540
+ }
541
+ this._origins = /* @__PURE__ */ new Set([...newOrigins.keys()]);
542
+ } catch (error) {
543
+ (0, import_stackTrace.rewriteErrorMessage)(error, `Error setting storage state:
544
+ ` + error.message);
545
+ throw error;
546
+ } finally {
547
+ if (mode !== "resetForReuse")
548
+ await page?.close();
549
+ else if (interceptor)
550
+ await page?.removeRequestInterceptor(interceptor);
551
+ }
552
+ }
553
+ async extendInjectedScript(source, arg) {
554
+ const installInFrame = (frame) => frame.extendInjectedScript(source, arg).catch(() => {
555
+ });
556
+ const installInPage = (page) => {
557
+ page.on(import_page2.Page.Events.InternalFrameNavigatedToNewDocument, installInFrame);
558
+ return Promise.all(page.frames().map(installInFrame));
559
+ };
560
+ this.on(BrowserContext.Events.Page, installInPage);
561
+ return Promise.all(this.pages().map(installInPage));
562
+ }
563
+ async safeNonStallingEvaluateInAllFrames(expression, world, options = {}) {
564
+ await Promise.all(this.pages().map((page) => page.safeNonStallingEvaluateInAllFrames(expression, world, options)));
565
+ }
566
+ harStart(page, options) {
567
+ const harId = (0, import_crypto.createGuid)();
568
+ this._harRecorders.set(harId, new import_harRecorder.HarRecorder(this, page, options));
569
+ return harId;
570
+ }
571
+ async harExport(harId) {
572
+ const recorder = this._harRecorders.get(harId || "");
573
+ return recorder.export();
574
+ }
575
+ addRouteInFlight(route) {
576
+ this._routesInFlight.add(route);
577
+ }
578
+ removeRouteInFlight(route) {
579
+ this._routesInFlight.delete(route);
580
+ }
581
+ async notifyRoutesInFlightAboutRemovedHandler(handler) {
582
+ await Promise.all([...this._routesInFlight].map((route) => route.removeHandler(handler)));
583
+ }
584
+ }
585
+ function validateBrowserContextOptions(options, browserOptions) {
586
+ if (options.noDefaultViewport && options.deviceScaleFactor !== void 0)
587
+ throw new Error(`"deviceScaleFactor" option is not supported with null "viewport"`);
588
+ if (options.noDefaultViewport && !!options.isMobile)
589
+ throw new Error(`"isMobile" option is not supported with null "viewport"`);
590
+ if (options.acceptDownloads === void 0 && browserOptions.name !== "electron")
591
+ options.acceptDownloads = "accept";
592
+ else if (options.acceptDownloads === void 0 && browserOptions.name === "electron")
593
+ options.acceptDownloads = "internal-browser-default";
594
+ if (!options.viewport && !options.noDefaultViewport)
595
+ options.viewport = { width: 1280, height: 720 };
596
+ if (options.proxy)
597
+ options.proxy = normalizeProxySettings(options.proxy);
598
+ verifyGeolocation(options.geolocation);
599
+ }
600
+ function verifyGeolocation(geolocation) {
601
+ if (!geolocation)
602
+ return;
603
+ geolocation.accuracy = geolocation.accuracy || 0;
604
+ const { longitude, latitude, accuracy } = geolocation;
605
+ if (longitude < -180 || longitude > 180)
606
+ throw new Error(`geolocation.longitude: precondition -180 <= LONGITUDE <= 180 failed.`);
607
+ if (latitude < -90 || latitude > 90)
608
+ throw new Error(`geolocation.latitude: precondition -90 <= LATITUDE <= 90 failed.`);
609
+ if (accuracy < 0)
610
+ throw new Error(`geolocation.accuracy: precondition 0 <= ACCURACY failed.`);
611
+ }
612
+ function verifyClientCertificates(clientCertificates) {
613
+ if (!clientCertificates)
614
+ return;
615
+ for (const cert of clientCertificates) {
616
+ if (!cert.origin)
617
+ throw new Error(`clientCertificates.origin is required`);
618
+ if (!cert.cert && !cert.key && !cert.passphrase && !cert.pfx)
619
+ throw new Error("None of cert, key, passphrase or pfx is specified");
620
+ if (cert.cert && !cert.key)
621
+ throw new Error("cert is specified without key");
622
+ if (!cert.cert && cert.key)
623
+ throw new Error("key is specified without cert");
624
+ if (cert.pfx && (cert.cert || cert.key))
625
+ throw new Error("pfx is specified together with cert, key or passphrase");
626
+ }
627
+ }
628
+ function normalizeProxySettings(proxy) {
629
+ let { server, bypass } = proxy;
630
+ let url;
631
+ try {
632
+ url = new URL(server);
633
+ if (!url.host || !url.protocol)
634
+ url = new URL("http://" + server);
635
+ } catch (e) {
636
+ url = new URL("http://" + server);
637
+ }
638
+ if (url.protocol === "socks4:" && (proxy.username || proxy.password))
639
+ throw new Error(`Socks4 proxy protocol does not support authentication`);
640
+ if (url.protocol === "socks5:" && (proxy.username || proxy.password))
641
+ throw new Error(`Browser does not support socks5 proxy authentication`);
642
+ server = url.protocol + "//" + url.host;
643
+ if (bypass)
644
+ bypass = bypass.split(",").map((t) => t.trim()).join(",");
645
+ return { ...proxy, server, bypass };
646
+ }
647
+ function calculateUserAgentEmulation(options) {
648
+ const ua = options.userAgent;
649
+ if (!ua)
650
+ return { navigatorPlatform: void 0, userAgentMetadata: void 0 };
651
+ const userAgentMetadata = {
652
+ mobile: !!options.isMobile,
653
+ model: "",
654
+ architecture: "x86",
655
+ platform: "Windows",
656
+ platformVersion: ""
657
+ };
658
+ const androidMatch = ua.match(/Android (\d+(\.\d+)?(\.\d+)?)/);
659
+ const iPhoneMatch = ua.match(/iPhone OS (\d+(_\d+)?)/);
660
+ const iPadMatch = ua.match(/iPad; CPU OS (\d+(_\d+)?)/);
661
+ const macOSMatch = ua.match(/Mac OS X (\d+(_\d+)?(_\d+)?)/);
662
+ const windowsMatch = ua.match(/Windows\D+(\d+(\.\d+)?(\.\d+)?)/);
663
+ if (androidMatch) {
664
+ userAgentMetadata.platform = "Android";
665
+ userAgentMetadata.platformVersion = androidMatch[1];
666
+ userAgentMetadata.architecture = "arm";
667
+ } else if (iPhoneMatch) {
668
+ userAgentMetadata.platform = "iOS";
669
+ userAgentMetadata.platformVersion = iPhoneMatch[1].replace(/_/g, ".");
670
+ userAgentMetadata.architecture = "arm";
671
+ } else if (iPadMatch) {
672
+ userAgentMetadata.platform = "iOS";
673
+ userAgentMetadata.platformVersion = iPadMatch[1].replace(/_/g, ".");
674
+ userAgentMetadata.architecture = "arm";
675
+ } else if (macOSMatch) {
676
+ userAgentMetadata.platform = "macOS";
677
+ userAgentMetadata.platformVersion = macOSMatch[1].replace(/_/g, ".");
678
+ if (!ua.includes("Intel"))
679
+ userAgentMetadata.architecture = "arm";
680
+ } else if (windowsMatch) {
681
+ userAgentMetadata.platform = "Windows";
682
+ userAgentMetadata.platformVersion = windowsMatch[1];
683
+ } else if (ua.toLowerCase().includes("linux")) {
684
+ userAgentMetadata.platform = "Linux";
685
+ }
686
+ if (ua.includes("ARM") || ua.includes("aarch64"))
687
+ userAgentMetadata.architecture = "arm";
688
+ let navigatorPlatform;
689
+ if (!process.env.PLAYWRIGHT_NO_UA_PLATFORM) {
690
+ switch (userAgentMetadata.platform) {
691
+ case "Android":
692
+ navigatorPlatform = userAgentMetadata.architecture === "arm" ? "Linux armv8l" : "Linux x86_64";
693
+ break;
694
+ case "iOS":
695
+ navigatorPlatform = ua.includes("iPad") ? "iPad" : "iPhone";
696
+ break;
697
+ case "macOS":
698
+ navigatorPlatform = "MacIntel";
699
+ break;
700
+ case "Linux":
701
+ navigatorPlatform = userAgentMetadata.architecture === "arm" ? "Linux aarch64" : "Linux x86_64";
702
+ break;
703
+ case "Windows":
704
+ navigatorPlatform = "Win32";
705
+ break;
706
+ }
707
+ }
708
+ return { navigatorPlatform, userAgentMetadata };
709
+ }
710
+ const paramsThatAllowContextReuse = [
711
+ "colorScheme",
712
+ "forcedColors",
713
+ "reducedMotion",
714
+ "contrast",
715
+ "screen",
716
+ "userAgent",
717
+ "viewport",
718
+ "testIdAttributeName"
719
+ ];
720
+ const defaultNewContextParamValues = {
721
+ noDefaultViewport: false,
722
+ ignoreHTTPSErrors: false,
723
+ javaScriptEnabled: true,
724
+ bypassCSP: false,
725
+ offline: false,
726
+ isMobile: false,
727
+ hasTouch: false,
728
+ acceptDownloads: "accept",
729
+ strictSelectors: false,
730
+ serviceWorkers: "allow",
731
+ locale: "en-US"
732
+ };
733
+ // Annotate the CommonJS export names for ESM import in node:
734
+ 0 && (module.exports = {
735
+ BrowserContext,
736
+ calculateUserAgentEmulation,
737
+ normalizeProxySettings,
738
+ validateBrowserContextOptions,
739
+ verifyClientCertificates,
740
+ verifyGeolocation
741
+ });