@pedropaulovc/playwright-core 1.59.0-next

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 (366) hide show
  1. package/README.md +3 -0
  2. package/ThirdPartyNotices.txt +4076 -0
  3. package/bin/install_media_pack.ps1 +5 -0
  4. package/bin/install_webkit_wsl.ps1 +33 -0
  5. package/bin/reinstall_chrome_beta_linux.sh +42 -0
  6. package/bin/reinstall_chrome_beta_mac.sh +13 -0
  7. package/bin/reinstall_chrome_beta_win.ps1 +24 -0
  8. package/bin/reinstall_chrome_stable_linux.sh +42 -0
  9. package/bin/reinstall_chrome_stable_mac.sh +12 -0
  10. package/bin/reinstall_chrome_stable_win.ps1 +24 -0
  11. package/bin/reinstall_msedge_beta_linux.sh +48 -0
  12. package/bin/reinstall_msedge_beta_mac.sh +11 -0
  13. package/bin/reinstall_msedge_beta_win.ps1 +23 -0
  14. package/bin/reinstall_msedge_dev_linux.sh +48 -0
  15. package/bin/reinstall_msedge_dev_mac.sh +11 -0
  16. package/bin/reinstall_msedge_dev_win.ps1 +23 -0
  17. package/bin/reinstall_msedge_stable_linux.sh +48 -0
  18. package/bin/reinstall_msedge_stable_mac.sh +11 -0
  19. package/bin/reinstall_msedge_stable_win.ps1 +24 -0
  20. package/browsers.json +79 -0
  21. package/cli.js +18 -0
  22. package/index.d.ts +17 -0
  23. package/index.js +32 -0
  24. package/index.mjs +28 -0
  25. package/lib/androidServerImpl.js +65 -0
  26. package/lib/browserServerImpl.js +120 -0
  27. package/lib/cli/driver.js +97 -0
  28. package/lib/cli/program.js +603 -0
  29. package/lib/cli/programWithTestStub.js +74 -0
  30. package/lib/client/android.js +361 -0
  31. package/lib/client/api.js +137 -0
  32. package/lib/client/artifact.js +79 -0
  33. package/lib/client/browser.js +161 -0
  34. package/lib/client/browserContext.js +582 -0
  35. package/lib/client/browserType.js +185 -0
  36. package/lib/client/cdpSession.js +51 -0
  37. package/lib/client/channelOwner.js +194 -0
  38. package/lib/client/clientHelper.js +64 -0
  39. package/lib/client/clientInstrumentation.js +55 -0
  40. package/lib/client/clientStackTrace.js +69 -0
  41. package/lib/client/clock.js +68 -0
  42. package/lib/client/connection.js +318 -0
  43. package/lib/client/consoleMessage.js +58 -0
  44. package/lib/client/coverage.js +44 -0
  45. package/lib/client/dialog.js +56 -0
  46. package/lib/client/download.js +62 -0
  47. package/lib/client/electron.js +138 -0
  48. package/lib/client/elementHandle.js +284 -0
  49. package/lib/client/errors.js +77 -0
  50. package/lib/client/eventEmitter.js +314 -0
  51. package/lib/client/events.js +103 -0
  52. package/lib/client/fetch.js +368 -0
  53. package/lib/client/fileChooser.js +46 -0
  54. package/lib/client/fileUtils.js +34 -0
  55. package/lib/client/frame.js +409 -0
  56. package/lib/client/harRouter.js +87 -0
  57. package/lib/client/input.js +84 -0
  58. package/lib/client/jsHandle.js +109 -0
  59. package/lib/client/jsonPipe.js +39 -0
  60. package/lib/client/localUtils.js +60 -0
  61. package/lib/client/locator.js +369 -0
  62. package/lib/client/network.js +747 -0
  63. package/lib/client/page.js +745 -0
  64. package/lib/client/pageAgent.js +64 -0
  65. package/lib/client/platform.js +77 -0
  66. package/lib/client/playwright.js +71 -0
  67. package/lib/client/selectors.js +55 -0
  68. package/lib/client/stream.js +39 -0
  69. package/lib/client/timeoutSettings.js +79 -0
  70. package/lib/client/tracing.js +119 -0
  71. package/lib/client/types.js +28 -0
  72. package/lib/client/video.js +59 -0
  73. package/lib/client/waiter.js +142 -0
  74. package/lib/client/webError.js +39 -0
  75. package/lib/client/webSocket.js +93 -0
  76. package/lib/client/worker.js +85 -0
  77. package/lib/client/writableStream.js +39 -0
  78. package/lib/generated/bindingsControllerSource.js +28 -0
  79. package/lib/generated/clockSource.js +28 -0
  80. package/lib/generated/injectedScriptSource.js +28 -0
  81. package/lib/generated/pollingRecorderSource.js +28 -0
  82. package/lib/generated/storageScriptSource.js +28 -0
  83. package/lib/generated/utilityScriptSource.js +28 -0
  84. package/lib/generated/webSocketMockSource.js +336 -0
  85. package/lib/inProcessFactory.js +60 -0
  86. package/lib/inprocess.js +3 -0
  87. package/lib/mcpBundle.js +84 -0
  88. package/lib/mcpBundleImpl/index.js +147 -0
  89. package/lib/outofprocess.js +76 -0
  90. package/lib/protocol/serializers.js +197 -0
  91. package/lib/protocol/validator.js +2969 -0
  92. package/lib/protocol/validatorPrimitives.js +193 -0
  93. package/lib/remote/playwrightConnection.js +129 -0
  94. package/lib/remote/playwrightServer.js +334 -0
  95. package/lib/server/agent/actionRunner.js +335 -0
  96. package/lib/server/agent/actions.js +128 -0
  97. package/lib/server/agent/codegen.js +111 -0
  98. package/lib/server/agent/context.js +150 -0
  99. package/lib/server/agent/expectTools.js +156 -0
  100. package/lib/server/agent/pageAgent.js +204 -0
  101. package/lib/server/agent/performTools.js +262 -0
  102. package/lib/server/agent/tool.js +109 -0
  103. package/lib/server/android/android.js +465 -0
  104. package/lib/server/android/backendAdb.js +177 -0
  105. package/lib/server/artifact.js +127 -0
  106. package/lib/server/bidi/bidiBrowser.js +549 -0
  107. package/lib/server/bidi/bidiChromium.js +148 -0
  108. package/lib/server/bidi/bidiConnection.js +213 -0
  109. package/lib/server/bidi/bidiDeserializer.js +116 -0
  110. package/lib/server/bidi/bidiExecutionContext.js +267 -0
  111. package/lib/server/bidi/bidiFirefox.js +128 -0
  112. package/lib/server/bidi/bidiInput.js +146 -0
  113. package/lib/server/bidi/bidiNetworkManager.js +383 -0
  114. package/lib/server/bidi/bidiOverCdp.js +102 -0
  115. package/lib/server/bidi/bidiPage.js +583 -0
  116. package/lib/server/bidi/bidiPdf.js +106 -0
  117. package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
  118. package/lib/server/bidi/third_party/bidiKeyboard.js +256 -0
  119. package/lib/server/bidi/third_party/bidiProtocol.js +24 -0
  120. package/lib/server/bidi/third_party/bidiProtocolCore.js +180 -0
  121. package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -0
  122. package/lib/server/bidi/third_party/bidiSerializer.js +148 -0
  123. package/lib/server/bidi/third_party/firefoxPrefs.js +259 -0
  124. package/lib/server/browser.js +149 -0
  125. package/lib/server/browserContext.js +702 -0
  126. package/lib/server/browserType.js +336 -0
  127. package/lib/server/callLog.js +82 -0
  128. package/lib/server/chromium/appIcon.png +0 -0
  129. package/lib/server/chromium/chromium.js +395 -0
  130. package/lib/server/chromium/chromiumSwitches.js +104 -0
  131. package/lib/server/chromium/crBrowser.js +511 -0
  132. package/lib/server/chromium/crConnection.js +197 -0
  133. package/lib/server/chromium/crCoverage.js +235 -0
  134. package/lib/server/chromium/crDevTools.js +111 -0
  135. package/lib/server/chromium/crDragDrop.js +131 -0
  136. package/lib/server/chromium/crExecutionContext.js +146 -0
  137. package/lib/server/chromium/crInput.js +187 -0
  138. package/lib/server/chromium/crNetworkManager.js +707 -0
  139. package/lib/server/chromium/crPage.js +1001 -0
  140. package/lib/server/chromium/crPdf.js +121 -0
  141. package/lib/server/chromium/crProtocolHelper.js +145 -0
  142. package/lib/server/chromium/crServiceWorker.js +136 -0
  143. package/lib/server/chromium/defaultFontFamilies.js +162 -0
  144. package/lib/server/chromium/protocol.d.js +16 -0
  145. package/lib/server/clock.js +149 -0
  146. package/lib/server/codegen/csharp.js +327 -0
  147. package/lib/server/codegen/java.js +274 -0
  148. package/lib/server/codegen/javascript.js +247 -0
  149. package/lib/server/codegen/jsonl.js +52 -0
  150. package/lib/server/codegen/language.js +132 -0
  151. package/lib/server/codegen/languages.js +68 -0
  152. package/lib/server/codegen/python.js +279 -0
  153. package/lib/server/codegen/types.js +16 -0
  154. package/lib/server/console.js +57 -0
  155. package/lib/server/cookieStore.js +206 -0
  156. package/lib/server/debugController.js +191 -0
  157. package/lib/server/debugger.js +119 -0
  158. package/lib/server/deviceDescriptors.js +39 -0
  159. package/lib/server/deviceDescriptorsSource.json +1779 -0
  160. package/lib/server/dialog.js +116 -0
  161. package/lib/server/dispatchers/androidDispatcher.js +325 -0
  162. package/lib/server/dispatchers/artifactDispatcher.js +118 -0
  163. package/lib/server/dispatchers/browserContextDispatcher.js +384 -0
  164. package/lib/server/dispatchers/browserDispatcher.js +118 -0
  165. package/lib/server/dispatchers/browserTypeDispatcher.js +64 -0
  166. package/lib/server/dispatchers/cdpSessionDispatcher.js +44 -0
  167. package/lib/server/dispatchers/debugControllerDispatcher.js +78 -0
  168. package/lib/server/dispatchers/dialogDispatcher.js +47 -0
  169. package/lib/server/dispatchers/dispatcher.js +364 -0
  170. package/lib/server/dispatchers/electronDispatcher.js +89 -0
  171. package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -0
  172. package/lib/server/dispatchers/frameDispatcher.js +227 -0
  173. package/lib/server/dispatchers/jsHandleDispatcher.js +85 -0
  174. package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -0
  175. package/lib/server/dispatchers/localUtilsDispatcher.js +149 -0
  176. package/lib/server/dispatchers/networkDispatchers.js +213 -0
  177. package/lib/server/dispatchers/pageAgentDispatcher.js +96 -0
  178. package/lib/server/dispatchers/pageDispatcher.js +393 -0
  179. package/lib/server/dispatchers/playwrightDispatcher.js +108 -0
  180. package/lib/server/dispatchers/streamDispatcher.js +67 -0
  181. package/lib/server/dispatchers/tracingDispatcher.js +68 -0
  182. package/lib/server/dispatchers/webSocketRouteDispatcher.js +165 -0
  183. package/lib/server/dispatchers/writableStreamDispatcher.js +79 -0
  184. package/lib/server/dom.js +815 -0
  185. package/lib/server/download.js +70 -0
  186. package/lib/server/electron/electron.js +273 -0
  187. package/lib/server/electron/loader.js +29 -0
  188. package/lib/server/errors.js +69 -0
  189. package/lib/server/fetch.js +621 -0
  190. package/lib/server/fileChooser.js +43 -0
  191. package/lib/server/fileUploadUtils.js +84 -0
  192. package/lib/server/firefox/ffBrowser.js +418 -0
  193. package/lib/server/firefox/ffConnection.js +142 -0
  194. package/lib/server/firefox/ffExecutionContext.js +150 -0
  195. package/lib/server/firefox/ffInput.js +159 -0
  196. package/lib/server/firefox/ffNetworkManager.js +256 -0
  197. package/lib/server/firefox/ffPage.js +497 -0
  198. package/lib/server/firefox/firefox.js +114 -0
  199. package/lib/server/firefox/protocol.d.js +16 -0
  200. package/lib/server/formData.js +147 -0
  201. package/lib/server/frameSelectors.js +160 -0
  202. package/lib/server/frames.js +1471 -0
  203. package/lib/server/har/harRecorder.js +147 -0
  204. package/lib/server/har/harTracer.js +607 -0
  205. package/lib/server/harBackend.js +157 -0
  206. package/lib/server/helper.js +96 -0
  207. package/lib/server/index.js +58 -0
  208. package/lib/server/input.js +277 -0
  209. package/lib/server/instrumentation.js +72 -0
  210. package/lib/server/javascript.js +291 -0
  211. package/lib/server/launchApp.js +128 -0
  212. package/lib/server/localUtils.js +214 -0
  213. package/lib/server/macEditingCommands.js +143 -0
  214. package/lib/server/network.js +667 -0
  215. package/lib/server/page.js +830 -0
  216. package/lib/server/pipeTransport.js +89 -0
  217. package/lib/server/playwright.js +69 -0
  218. package/lib/server/progress.js +132 -0
  219. package/lib/server/protocolError.js +52 -0
  220. package/lib/server/recorder/chat.js +161 -0
  221. package/lib/server/recorder/recorderApp.js +366 -0
  222. package/lib/server/recorder/recorderRunner.js +138 -0
  223. package/lib/server/recorder/recorderSignalProcessor.js +83 -0
  224. package/lib/server/recorder/recorderUtils.js +157 -0
  225. package/lib/server/recorder/throttledFile.js +57 -0
  226. package/lib/server/recorder.js +499 -0
  227. package/lib/server/registry/browserFetcher.js +177 -0
  228. package/lib/server/registry/dependencies.js +371 -0
  229. package/lib/server/registry/index.js +1422 -0
  230. package/lib/server/registry/nativeDeps.js +1280 -0
  231. package/lib/server/registry/oopDownloadBrowserMain.js +127 -0
  232. package/lib/server/screencast.js +190 -0
  233. package/lib/server/screenshotter.js +333 -0
  234. package/lib/server/selectors.js +112 -0
  235. package/lib/server/socksClientCertificatesInterceptor.js +383 -0
  236. package/lib/server/socksInterceptor.js +95 -0
  237. package/lib/server/trace/recorder/snapshotter.js +147 -0
  238. package/lib/server/trace/recorder/snapshotterInjected.js +561 -0
  239. package/lib/server/trace/recorder/tracing.js +604 -0
  240. package/lib/server/trace/viewer/traceExporter.js +679 -0
  241. package/lib/server/trace/viewer/traceParser.js +72 -0
  242. package/lib/server/trace/viewer/traceViewer.js +245 -0
  243. package/lib/server/transport.js +181 -0
  244. package/lib/server/types.js +28 -0
  245. package/lib/server/usKeyboardLayout.js +145 -0
  246. package/lib/server/utils/ascii.js +44 -0
  247. package/lib/server/utils/comparators.js +139 -0
  248. package/lib/server/utils/crypto.js +216 -0
  249. package/lib/server/utils/debug.js +42 -0
  250. package/lib/server/utils/debugLogger.js +122 -0
  251. package/lib/server/utils/env.js +73 -0
  252. package/lib/server/utils/eventsHelper.js +39 -0
  253. package/lib/server/utils/expectUtils.js +123 -0
  254. package/lib/server/utils/fileUtils.js +191 -0
  255. package/lib/server/utils/happyEyeballs.js +207 -0
  256. package/lib/server/utils/hostPlatform.js +123 -0
  257. package/lib/server/utils/httpServer.js +203 -0
  258. package/lib/server/utils/imageUtils.js +141 -0
  259. package/lib/server/utils/image_tools/colorUtils.js +89 -0
  260. package/lib/server/utils/image_tools/compare.js +109 -0
  261. package/lib/server/utils/image_tools/imageChannel.js +78 -0
  262. package/lib/server/utils/image_tools/stats.js +102 -0
  263. package/lib/server/utils/linuxUtils.js +71 -0
  264. package/lib/server/utils/network.js +242 -0
  265. package/lib/server/utils/nodePlatform.js +154 -0
  266. package/lib/server/utils/pipeTransport.js +84 -0
  267. package/lib/server/utils/processLauncher.js +241 -0
  268. package/lib/server/utils/profiler.js +65 -0
  269. package/lib/server/utils/socksProxy.js +511 -0
  270. package/lib/server/utils/spawnAsync.js +41 -0
  271. package/lib/server/utils/task.js +51 -0
  272. package/lib/server/utils/userAgent.js +98 -0
  273. package/lib/server/utils/wsServer.js +121 -0
  274. package/lib/server/utils/zipFile.js +74 -0
  275. package/lib/server/utils/zones.js +57 -0
  276. package/lib/server/videoRecorder.js +124 -0
  277. package/lib/server/webkit/protocol.d.js +16 -0
  278. package/lib/server/webkit/webkit.js +108 -0
  279. package/lib/server/webkit/wkBrowser.js +335 -0
  280. package/lib/server/webkit/wkConnection.js +144 -0
  281. package/lib/server/webkit/wkExecutionContext.js +154 -0
  282. package/lib/server/webkit/wkInput.js +181 -0
  283. package/lib/server/webkit/wkInterceptableRequest.js +197 -0
  284. package/lib/server/webkit/wkPage.js +1158 -0
  285. package/lib/server/webkit/wkProvisionalPage.js +83 -0
  286. package/lib/server/webkit/wkWorkers.js +105 -0
  287. package/lib/third_party/pixelmatch.js +255 -0
  288. package/lib/utils/isomorphic/ariaSnapshot.js +455 -0
  289. package/lib/utils/isomorphic/assert.js +31 -0
  290. package/lib/utils/isomorphic/colors.js +72 -0
  291. package/lib/utils/isomorphic/cssParser.js +245 -0
  292. package/lib/utils/isomorphic/cssTokenizer.js +1051 -0
  293. package/lib/utils/isomorphic/headers.js +53 -0
  294. package/lib/utils/isomorphic/locatorGenerators.js +689 -0
  295. package/lib/utils/isomorphic/locatorParser.js +176 -0
  296. package/lib/utils/isomorphic/locatorUtils.js +81 -0
  297. package/lib/utils/isomorphic/lruCache.js +51 -0
  298. package/lib/utils/isomorphic/manualPromise.js +114 -0
  299. package/lib/utils/isomorphic/mimeType.js +459 -0
  300. package/lib/utils/isomorphic/multimap.js +80 -0
  301. package/lib/utils/isomorphic/protocolFormatter.js +81 -0
  302. package/lib/utils/isomorphic/protocolMetainfo.js +330 -0
  303. package/lib/utils/isomorphic/rtti.js +43 -0
  304. package/lib/utils/isomorphic/selectorParser.js +386 -0
  305. package/lib/utils/isomorphic/semaphore.js +54 -0
  306. package/lib/utils/isomorphic/stackTrace.js +158 -0
  307. package/lib/utils/isomorphic/stringUtils.js +204 -0
  308. package/lib/utils/isomorphic/time.js +49 -0
  309. package/lib/utils/isomorphic/timeoutRunner.js +66 -0
  310. package/lib/utils/isomorphic/trace/entries.js +16 -0
  311. package/lib/utils/isomorphic/trace/snapshotRenderer.js +499 -0
  312. package/lib/utils/isomorphic/trace/snapshotServer.js +120 -0
  313. package/lib/utils/isomorphic/trace/snapshotStorage.js +89 -0
  314. package/lib/utils/isomorphic/trace/traceLoader.js +131 -0
  315. package/lib/utils/isomorphic/trace/traceModel.js +365 -0
  316. package/lib/utils/isomorphic/trace/traceModernizer.js +400 -0
  317. package/lib/utils/isomorphic/trace/versions/traceV3.js +16 -0
  318. package/lib/utils/isomorphic/trace/versions/traceV4.js +16 -0
  319. package/lib/utils/isomorphic/trace/versions/traceV5.js +16 -0
  320. package/lib/utils/isomorphic/trace/versions/traceV6.js +16 -0
  321. package/lib/utils/isomorphic/trace/versions/traceV7.js +16 -0
  322. package/lib/utils/isomorphic/trace/versions/traceV8.js +16 -0
  323. package/lib/utils/isomorphic/traceUtils.js +58 -0
  324. package/lib/utils/isomorphic/types.js +16 -0
  325. package/lib/utils/isomorphic/urlMatch.js +190 -0
  326. package/lib/utils/isomorphic/utilityScriptSerializers.js +251 -0
  327. package/lib/utils/isomorphic/yaml.js +84 -0
  328. package/lib/utils.js +111 -0
  329. package/lib/utilsBundle.js +109 -0
  330. package/lib/utilsBundleImpl/index.js +218 -0
  331. package/lib/utilsBundleImpl/xdg-open +1066 -0
  332. package/lib/vite/htmlReport/index.html +84 -0
  333. package/lib/vite/recorder/assets/codeMirrorModule-DYBRYzYX.css +1 -0
  334. package/lib/vite/recorder/assets/codeMirrorModule-DadYNm1I.js +32 -0
  335. package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  336. package/lib/vite/recorder/assets/index-BSjZa4pk.css +1 -0
  337. package/lib/vite/recorder/assets/index-BhTWtUlo.js +193 -0
  338. package/lib/vite/recorder/index.html +29 -0
  339. package/lib/vite/recorder/playwright-logo.svg +9 -0
  340. package/lib/vite/traceViewer/assets/codeMirrorModule-DwzBH9eL.js +32 -0
  341. package/lib/vite/traceViewer/assets/codeMirrorModule-a5XoALAZ.js +32 -0
  342. package/lib/vite/traceViewer/assets/defaultSettingsView-CJSZINFr.js +266 -0
  343. package/lib/vite/traceViewer/assets/defaultSettingsView-CdCX8877.js +266 -0
  344. package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
  345. package/lib/vite/traceViewer/codeMirrorModule.DYBRYzYX.css +1 -0
  346. package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  347. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +1 -0
  348. package/lib/vite/traceViewer/index.BVu7tZDe.css +1 -0
  349. package/lib/vite/traceViewer/index.Dd9jebqr.js +2 -0
  350. package/lib/vite/traceViewer/index.f4OcrOqs.js +2 -0
  351. package/lib/vite/traceViewer/index.html +43 -0
  352. package/lib/vite/traceViewer/manifest.webmanifest +16 -0
  353. package/lib/vite/traceViewer/playwright-logo.svg +9 -0
  354. package/lib/vite/traceViewer/snapshot.html +21 -0
  355. package/lib/vite/traceViewer/sw.bundle.js +5 -0
  356. package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
  357. package/lib/vite/traceViewer/uiMode.CQJ9SCIQ.js +5 -0
  358. package/lib/vite/traceViewer/uiMode.html +17 -0
  359. package/lib/vite/traceViewer/uiMode.qcahlSup.js +5 -0
  360. package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -0
  361. package/lib/zipBundle.js +34 -0
  362. package/lib/zipBundleImpl.js +5 -0
  363. package/package.json +43 -0
  364. package/types/protocol.d.ts +23824 -0
  365. package/types/structs.d.ts +45 -0
  366. package/types/types.d.ts +22843 -0
@@ -0,0 +1,1422 @@
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 registry_exports = {};
30
+ __export(registry_exports, {
31
+ Registry: () => Registry,
32
+ browserDirectoryToMarkerFilePath: () => browserDirectoryToMarkerFilePath,
33
+ buildPlaywrightCLICommand: () => buildPlaywrightCLICommand,
34
+ findChromiumChannelBestEffort: () => findChromiumChannelBestEffort,
35
+ installBrowsersForNpmInstall: () => installBrowsersForNpmInstall,
36
+ registry: () => registry,
37
+ registryDirectory: () => registryDirectory,
38
+ writeDockerVersion: () => import_dependencies3.writeDockerVersion
39
+ });
40
+ module.exports = __toCommonJS(registry_exports);
41
+ var import_fs = __toESM(require("fs"));
42
+ var import_os = __toESM(require("os"));
43
+ var import_path = __toESM(require("path"));
44
+ var util = __toESM(require("util"));
45
+ var import_browserFetcher = require("./browserFetcher");
46
+ var import_dependencies = require("./dependencies");
47
+ var import_dependencies2 = require("./dependencies");
48
+ var import_utils = require("../../utils");
49
+ var import_ascii = require("../utils/ascii");
50
+ var import_debugLogger = require("../utils/debugLogger");
51
+ var import_hostPlatform = require("../utils/hostPlatform");
52
+ var import_network = require("../utils/network");
53
+ var import_spawnAsync = require("../utils/spawnAsync");
54
+ var import_userAgent = require("../utils/userAgent");
55
+ var import_utilsBundle = require("../../utilsBundle");
56
+ var import_fileUtils = require("../utils/fileUtils");
57
+ var import_dependencies3 = require("./dependencies");
58
+ const PACKAGE_PATH = import_path.default.join(__dirname, "..", "..", "..");
59
+ const BIN_PATH = import_path.default.join(__dirname, "..", "..", "..", "bin");
60
+ const PLAYWRIGHT_CDN_MIRRORS = [
61
+ "https://cdn.playwright.dev/dbazure/download/playwright",
62
+ // ESRP CDN
63
+ "https://playwright.download.prss.microsoft.com/dbazure/download/playwright",
64
+ // Directly hit ESRP CDN
65
+ "https://cdn.playwright.dev"
66
+ // Hit the Storage Bucket directly
67
+ ];
68
+ if (process.env.PW_TEST_CDN_THAT_SHOULD_WORK) {
69
+ for (let i = 0; i < PLAYWRIGHT_CDN_MIRRORS.length; i++) {
70
+ const cdn = PLAYWRIGHT_CDN_MIRRORS[i];
71
+ if (cdn !== process.env.PW_TEST_CDN_THAT_SHOULD_WORK) {
72
+ const parsedCDN = new URL(cdn);
73
+ parsedCDN.hostname = parsedCDN.hostname + ".does-not-resolve.playwright.dev";
74
+ PLAYWRIGHT_CDN_MIRRORS[i] = parsedCDN.toString();
75
+ }
76
+ }
77
+ }
78
+ const EXECUTABLE_PATHS = {
79
+ "chromium": {
80
+ "<unknown>": void 0,
81
+ "linux-x64": ["chrome-linux64", "chrome"],
82
+ "linux-arm64": ["chrome-linux", "chrome"],
83
+ // non-cft build
84
+ "mac-x64": ["chrome-mac-x64", "Google Chrome for Testing.app", "Contents", "MacOS", "Google Chrome for Testing"],
85
+ "mac-arm64": ["chrome-mac-arm64", "Google Chrome for Testing.app", "Contents", "MacOS", "Google Chrome for Testing"],
86
+ "win-x64": ["chrome-win64", "chrome.exe"]
87
+ },
88
+ "chromium-headless-shell": {
89
+ "<unknown>": void 0,
90
+ "linux-x64": ["chrome-headless-shell-linux64", "chrome-headless-shell"],
91
+ "linux-arm64": ["chrome-linux", "headless_shell"],
92
+ // non-cft build
93
+ "mac-x64": ["chrome-headless-shell-mac-x64", "chrome-headless-shell"],
94
+ "mac-arm64": ["chrome-headless-shell-mac-arm64", "chrome-headless-shell"],
95
+ "win-x64": ["chrome-headless-shell-win64", "chrome-headless-shell.exe"]
96
+ },
97
+ "chromium-tip-of-tree": {
98
+ "<unknown>": void 0,
99
+ "linux-x64": ["chrome-linux64", "chrome"],
100
+ "linux-arm64": ["chrome-linux", "chrome"],
101
+ // non-cft build
102
+ "mac-x64": ["chrome-mac-x64", "Google Chrome for Testing.app", "Contents", "MacOS", "Google Chrome for Testing"],
103
+ "mac-arm64": ["chrome-mac-arm64", "Google Chrome for Testing.app", "Contents", "MacOS", "Google Chrome for Testing"],
104
+ "win-x64": ["chrome-win64", "chrome.exe"]
105
+ },
106
+ "chromium-tip-of-tree-headless-shell": {
107
+ "<unknown>": void 0,
108
+ "linux-x64": ["chrome-headless-shell-linux64", "chrome-headless-shell"],
109
+ "linux-arm64": ["chrome-linux", "headless_shell"],
110
+ // non-cft build
111
+ "mac-x64": ["chrome-headless-shell-mac-x64", "chrome-headless-shell"],
112
+ "mac-arm64": ["chrome-headless-shell-mac-arm64", "chrome-headless-shell"],
113
+ "win-x64": ["chrome-headless-shell-win64", "chrome-headless-shell.exe"]
114
+ },
115
+ "firefox": {
116
+ "<unknown>": void 0,
117
+ "linux-x64": ["firefox", "firefox"],
118
+ "linux-arm64": ["firefox", "firefox"],
119
+ "mac-x64": ["firefox", "Nightly.app", "Contents", "MacOS", "firefox"],
120
+ "mac-arm64": ["firefox", "Nightly.app", "Contents", "MacOS", "firefox"],
121
+ "win-x64": ["firefox", "firefox.exe"]
122
+ },
123
+ "webkit": {
124
+ "<unknown>": void 0,
125
+ "linux-x64": ["pw_run.sh"],
126
+ "linux-arm64": ["pw_run.sh"],
127
+ "mac-x64": ["pw_run.sh"],
128
+ "mac-arm64": ["pw_run.sh"],
129
+ "win-x64": ["Playwright.exe"]
130
+ },
131
+ "ffmpeg": {
132
+ "<unknown>": void 0,
133
+ "linux-x64": ["ffmpeg-linux"],
134
+ "linux-arm64": ["ffmpeg-linux"],
135
+ "mac-x64": ["ffmpeg-mac"],
136
+ "mac-arm64": ["ffmpeg-mac"],
137
+ "win-x64": ["ffmpeg-win64.exe"]
138
+ },
139
+ "winldd": {
140
+ "<unknown>": void 0,
141
+ "linux-x64": void 0,
142
+ "linux-arm64": void 0,
143
+ "mac-x64": void 0,
144
+ "mac-arm64": void 0,
145
+ "win-x64": ["PrintDeps.exe"]
146
+ }
147
+ };
148
+ function cftUrl(suffix) {
149
+ return ({ browserVersion }) => {
150
+ return {
151
+ path: `${browserVersion}/${suffix}`,
152
+ mirrors: [
153
+ "https://cdn.playwright.dev/chrome-for-testing-public"
154
+ ]
155
+ };
156
+ };
157
+ }
158
+ const DOWNLOAD_PATHS = {
159
+ "chromium": {
160
+ "<unknown>": void 0,
161
+ "ubuntu18.04-x64": void 0,
162
+ "ubuntu20.04-x64": cftUrl("linux64/chrome-linux64.zip"),
163
+ "ubuntu22.04-x64": cftUrl("linux64/chrome-linux64.zip"),
164
+ "ubuntu24.04-x64": cftUrl("linux64/chrome-linux64.zip"),
165
+ "ubuntu18.04-arm64": void 0,
166
+ "ubuntu20.04-arm64": "builds/chromium/%s/chromium-linux-arm64.zip",
167
+ "ubuntu22.04-arm64": "builds/chromium/%s/chromium-linux-arm64.zip",
168
+ "ubuntu24.04-arm64": "builds/chromium/%s/chromium-linux-arm64.zip",
169
+ "debian11-x64": cftUrl("linux64/chrome-linux64.zip"),
170
+ "debian11-arm64": "builds/chromium/%s/chromium-linux-arm64.zip",
171
+ "debian12-x64": cftUrl("linux64/chrome-linux64.zip"),
172
+ "debian12-arm64": "builds/chromium/%s/chromium-linux-arm64.zip",
173
+ "debian13-x64": cftUrl("linux64/chrome-linux64.zip"),
174
+ "debian13-arm64": "builds/chromium/%s/chromium-linux-arm64.zip",
175
+ "mac10.13": cftUrl("mac-x64/chrome-mac-x64.zip"),
176
+ "mac10.14": cftUrl("mac-x64/chrome-mac-x64.zip"),
177
+ "mac10.15": cftUrl("mac-x64/chrome-mac-x64.zip"),
178
+ "mac11": cftUrl("mac-x64/chrome-mac-x64.zip"),
179
+ "mac11-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
180
+ "mac12": cftUrl("mac-x64/chrome-mac-x64.zip"),
181
+ "mac12-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
182
+ "mac13": cftUrl("mac-x64/chrome-mac-x64.zip"),
183
+ "mac13-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
184
+ "mac14": cftUrl("mac-x64/chrome-mac-x64.zip"),
185
+ "mac14-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
186
+ "mac15": cftUrl("mac-x64/chrome-mac-x64.zip"),
187
+ "mac15-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
188
+ "win64": cftUrl("win64/chrome-win64.zip")
189
+ },
190
+ "chromium-headless-shell": {
191
+ "<unknown>": void 0,
192
+ "ubuntu18.04-x64": void 0,
193
+ "ubuntu20.04-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
194
+ "ubuntu22.04-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
195
+ "ubuntu24.04-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
196
+ "ubuntu18.04-arm64": void 0,
197
+ "ubuntu20.04-arm64": "builds/chromium/%s/chromium-headless-shell-linux-arm64.zip",
198
+ "ubuntu22.04-arm64": "builds/chromium/%s/chromium-headless-shell-linux-arm64.zip",
199
+ "ubuntu24.04-arm64": "builds/chromium/%s/chromium-headless-shell-linux-arm64.zip",
200
+ "debian11-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
201
+ "debian11-arm64": "builds/chromium/%s/chromium-headless-shell-linux-arm64.zip",
202
+ "debian12-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
203
+ "debian12-arm64": "builds/chromium/%s/chromium-headless-shell-linux-arm64.zip",
204
+ "debian13-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
205
+ "debian13-arm64": "builds/chromium/%s/chromium-headless-shell-linux-arm64.zip",
206
+ "mac10.13": void 0,
207
+ "mac10.14": void 0,
208
+ "mac10.15": void 0,
209
+ "mac11": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
210
+ "mac11-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
211
+ "mac12": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
212
+ "mac12-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
213
+ "mac13": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
214
+ "mac13-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
215
+ "mac14": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
216
+ "mac14-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
217
+ "mac15": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
218
+ "mac15-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
219
+ "win64": cftUrl("win64/chrome-headless-shell-win64.zip")
220
+ },
221
+ "chromium-tip-of-tree": {
222
+ "<unknown>": void 0,
223
+ "ubuntu18.04-x64": void 0,
224
+ "ubuntu20.04-x64": cftUrl("linux64/chrome-linux64.zip"),
225
+ "ubuntu22.04-x64": cftUrl("linux64/chrome-linux64.zip"),
226
+ "ubuntu24.04-x64": cftUrl("linux64/chrome-linux64.zip"),
227
+ "ubuntu18.04-arm64": void 0,
228
+ "ubuntu20.04-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-linux-arm64.zip",
229
+ "ubuntu22.04-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-linux-arm64.zip",
230
+ "ubuntu24.04-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-linux-arm64.zip",
231
+ "debian11-x64": cftUrl("linux64/chrome-linux64.zip"),
232
+ "debian11-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-linux-arm64.zip",
233
+ "debian12-x64": cftUrl("linux64/chrome-linux64.zip"),
234
+ "debian12-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-linux-arm64.zip",
235
+ "debian13-x64": cftUrl("linux64/chrome-linux64.zip"),
236
+ "debian13-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-linux-arm64.zip",
237
+ "mac10.13": cftUrl("mac-x64/chrome-mac-x64.zip"),
238
+ "mac10.14": cftUrl("mac-x64/chrome-mac-x64.zip"),
239
+ "mac10.15": cftUrl("mac-x64/chrome-mac-x64.zip"),
240
+ "mac11": cftUrl("mac-x64/chrome-mac-x64.zip"),
241
+ "mac11-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
242
+ "mac12": cftUrl("mac-x64/chrome-mac-x64.zip"),
243
+ "mac12-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
244
+ "mac13": cftUrl("mac-x64/chrome-mac-x64.zip"),
245
+ "mac13-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
246
+ "mac14": cftUrl("mac-x64/chrome-mac-x64.zip"),
247
+ "mac14-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
248
+ "mac15": cftUrl("mac-x64/chrome-mac-x64.zip"),
249
+ "mac15-arm64": cftUrl("mac-arm64/chrome-mac-arm64.zip"),
250
+ "win64": cftUrl("win64/chrome-win64.zip")
251
+ },
252
+ "chromium-tip-of-tree-headless-shell": {
253
+ "<unknown>": void 0,
254
+ "ubuntu18.04-x64": void 0,
255
+ "ubuntu20.04-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
256
+ "ubuntu22.04-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
257
+ "ubuntu24.04-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
258
+ "ubuntu18.04-arm64": void 0,
259
+ "ubuntu20.04-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-headless-shell-linux-arm64.zip",
260
+ "ubuntu22.04-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-headless-shell-linux-arm64.zip",
261
+ "ubuntu24.04-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-headless-shell-linux-arm64.zip",
262
+ "debian11-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
263
+ "debian11-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-headless-shell-linux-arm64.zip",
264
+ "debian12-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
265
+ "debian12-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-headless-shell-linux-arm64.zip",
266
+ "debian13-x64": cftUrl("linux64/chrome-headless-shell-linux64.zip"),
267
+ "debian13-arm64": "builds/chromium-tip-of-tree/%s/chromium-tip-of-tree-headless-shell-linux-arm64.zip",
268
+ "mac10.13": void 0,
269
+ "mac10.14": void 0,
270
+ "mac10.15": void 0,
271
+ "mac11": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
272
+ "mac11-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
273
+ "mac12": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
274
+ "mac12-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
275
+ "mac13": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
276
+ "mac13-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
277
+ "mac14": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
278
+ "mac14-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
279
+ "mac15": cftUrl("mac-x64/chrome-headless-shell-mac-x64.zip"),
280
+ "mac15-arm64": cftUrl("mac-arm64/chrome-headless-shell-mac-arm64.zip"),
281
+ "win64": cftUrl("win64/chrome-headless-shell-win64.zip")
282
+ },
283
+ "firefox": {
284
+ "<unknown>": void 0,
285
+ "ubuntu18.04-x64": void 0,
286
+ "ubuntu20.04-x64": "builds/firefox/%s/firefox-ubuntu-20.04.zip",
287
+ "ubuntu22.04-x64": "builds/firefox/%s/firefox-ubuntu-22.04.zip",
288
+ "ubuntu24.04-x64": "builds/firefox/%s/firefox-ubuntu-24.04.zip",
289
+ "ubuntu18.04-arm64": void 0,
290
+ "ubuntu20.04-arm64": "builds/firefox/%s/firefox-ubuntu-20.04-arm64.zip",
291
+ "ubuntu22.04-arm64": "builds/firefox/%s/firefox-ubuntu-22.04-arm64.zip",
292
+ "ubuntu24.04-arm64": "builds/firefox/%s/firefox-ubuntu-24.04-arm64.zip",
293
+ "debian11-x64": "builds/firefox/%s/firefox-debian-11.zip",
294
+ "debian11-arm64": "builds/firefox/%s/firefox-debian-11-arm64.zip",
295
+ "debian12-x64": "builds/firefox/%s/firefox-debian-12.zip",
296
+ "debian12-arm64": "builds/firefox/%s/firefox-debian-12-arm64.zip",
297
+ "debian13-x64": "builds/firefox/%s/firefox-debian-13.zip",
298
+ "debian13-arm64": "builds/firefox/%s/firefox-debian-13-arm64.zip",
299
+ "mac10.13": "builds/firefox/%s/firefox-mac.zip",
300
+ "mac10.14": "builds/firefox/%s/firefox-mac.zip",
301
+ "mac10.15": "builds/firefox/%s/firefox-mac.zip",
302
+ "mac11": "builds/firefox/%s/firefox-mac.zip",
303
+ "mac11-arm64": "builds/firefox/%s/firefox-mac-arm64.zip",
304
+ "mac12": "builds/firefox/%s/firefox-mac.zip",
305
+ "mac12-arm64": "builds/firefox/%s/firefox-mac-arm64.zip",
306
+ "mac13": "builds/firefox/%s/firefox-mac.zip",
307
+ "mac13-arm64": "builds/firefox/%s/firefox-mac-arm64.zip",
308
+ "mac14": "builds/firefox/%s/firefox-mac.zip",
309
+ "mac14-arm64": "builds/firefox/%s/firefox-mac-arm64.zip",
310
+ "mac15": "builds/firefox/%s/firefox-mac.zip",
311
+ "mac15-arm64": "builds/firefox/%s/firefox-mac-arm64.zip",
312
+ "win64": "builds/firefox/%s/firefox-win64.zip"
313
+ },
314
+ "firefox-beta": {
315
+ "<unknown>": void 0,
316
+ "ubuntu18.04-x64": void 0,
317
+ "ubuntu20.04-x64": "builds/firefox-beta/%s/firefox-beta-ubuntu-20.04.zip",
318
+ "ubuntu22.04-x64": "builds/firefox-beta/%s/firefox-beta-ubuntu-22.04.zip",
319
+ "ubuntu24.04-x64": "builds/firefox-beta/%s/firefox-beta-ubuntu-24.04.zip",
320
+ "ubuntu18.04-arm64": void 0,
321
+ "ubuntu20.04-arm64": void 0,
322
+ "ubuntu22.04-arm64": "builds/firefox-beta/%s/firefox-beta-ubuntu-22.04-arm64.zip",
323
+ "ubuntu24.04-arm64": "builds/firefox-beta/%s/firefox-beta-ubuntu-24.04-arm64.zip",
324
+ "debian11-x64": "builds/firefox-beta/%s/firefox-beta-debian-11.zip",
325
+ "debian11-arm64": "builds/firefox-beta/%s/firefox-beta-debian-11-arm64.zip",
326
+ "debian12-x64": "builds/firefox-beta/%s/firefox-beta-debian-12.zip",
327
+ "debian12-arm64": "builds/firefox-beta/%s/firefox-beta-debian-12-arm64.zip",
328
+ "debian13-x64": "builds/firefox-beta/%s/firefox-beta-debian-12.zip",
329
+ "debian13-arm64": "builds/firefox-beta/%s/firefox-beta-debian-12-arm64.zip",
330
+ "mac10.13": "builds/firefox-beta/%s/firefox-beta-mac.zip",
331
+ "mac10.14": "builds/firefox-beta/%s/firefox-beta-mac.zip",
332
+ "mac10.15": "builds/firefox-beta/%s/firefox-beta-mac.zip",
333
+ "mac11": "builds/firefox-beta/%s/firefox-beta-mac.zip",
334
+ "mac11-arm64": "builds/firefox-beta/%s/firefox-beta-mac-arm64.zip",
335
+ "mac12": "builds/firefox-beta/%s/firefox-beta-mac.zip",
336
+ "mac12-arm64": "builds/firefox-beta/%s/firefox-beta-mac-arm64.zip",
337
+ "mac13": "builds/firefox-beta/%s/firefox-beta-mac.zip",
338
+ "mac13-arm64": "builds/firefox-beta/%s/firefox-beta-mac-arm64.zip",
339
+ "mac14": "builds/firefox-beta/%s/firefox-beta-mac.zip",
340
+ "mac14-arm64": "builds/firefox-beta/%s/firefox-beta-mac-arm64.zip",
341
+ "mac15": "builds/firefox-beta/%s/firefox-beta-mac.zip",
342
+ "mac15-arm64": "builds/firefox-beta/%s/firefox-beta-mac-arm64.zip",
343
+ "win64": "builds/firefox-beta/%s/firefox-beta-win64.zip"
344
+ },
345
+ "webkit": {
346
+ "<unknown>": void 0,
347
+ "ubuntu18.04-x64": void 0,
348
+ "ubuntu20.04-x64": "builds/webkit/%s/webkit-ubuntu-20.04.zip",
349
+ "ubuntu22.04-x64": "builds/webkit/%s/webkit-ubuntu-22.04.zip",
350
+ "ubuntu24.04-x64": "builds/webkit/%s/webkit-ubuntu-24.04.zip",
351
+ "ubuntu18.04-arm64": void 0,
352
+ "ubuntu20.04-arm64": "builds/webkit/%s/webkit-ubuntu-20.04-arm64.zip",
353
+ "ubuntu22.04-arm64": "builds/webkit/%s/webkit-ubuntu-22.04-arm64.zip",
354
+ "ubuntu24.04-arm64": "builds/webkit/%s/webkit-ubuntu-24.04-arm64.zip",
355
+ "debian11-x64": "builds/webkit/%s/webkit-debian-11.zip",
356
+ "debian11-arm64": "builds/webkit/%s/webkit-debian-11-arm64.zip",
357
+ "debian12-x64": "builds/webkit/%s/webkit-debian-12.zip",
358
+ "debian12-arm64": "builds/webkit/%s/webkit-debian-12-arm64.zip",
359
+ "debian13-x64": "builds/webkit/%s/webkit-debian-13.zip",
360
+ "debian13-arm64": "builds/webkit/%s/webkit-debian-13-arm64.zip",
361
+ "mac10.13": void 0,
362
+ "mac10.14": void 0,
363
+ "mac10.15": void 0,
364
+ "mac11": void 0,
365
+ "mac11-arm64": void 0,
366
+ "mac12": void 0,
367
+ "mac12-arm64": void 0,
368
+ "mac13": void 0,
369
+ "mac13-arm64": void 0,
370
+ "mac14": "builds/webkit/%s/webkit-mac-14.zip",
371
+ "mac14-arm64": "builds/webkit/%s/webkit-mac-14-arm64.zip",
372
+ "mac15": "builds/webkit/%s/webkit-mac-15.zip",
373
+ "mac15-arm64": "builds/webkit/%s/webkit-mac-15-arm64.zip",
374
+ "win64": "builds/webkit/%s/webkit-win64.zip"
375
+ },
376
+ "ffmpeg": {
377
+ "<unknown>": void 0,
378
+ "ubuntu18.04-x64": void 0,
379
+ "ubuntu20.04-x64": "builds/ffmpeg/%s/ffmpeg-linux.zip",
380
+ "ubuntu22.04-x64": "builds/ffmpeg/%s/ffmpeg-linux.zip",
381
+ "ubuntu24.04-x64": "builds/ffmpeg/%s/ffmpeg-linux.zip",
382
+ "ubuntu18.04-arm64": void 0,
383
+ "ubuntu20.04-arm64": "builds/ffmpeg/%s/ffmpeg-linux-arm64.zip",
384
+ "ubuntu22.04-arm64": "builds/ffmpeg/%s/ffmpeg-linux-arm64.zip",
385
+ "ubuntu24.04-arm64": "builds/ffmpeg/%s/ffmpeg-linux-arm64.zip",
386
+ "debian11-x64": "builds/ffmpeg/%s/ffmpeg-linux.zip",
387
+ "debian11-arm64": "builds/ffmpeg/%s/ffmpeg-linux-arm64.zip",
388
+ "debian12-x64": "builds/ffmpeg/%s/ffmpeg-linux.zip",
389
+ "debian12-arm64": "builds/ffmpeg/%s/ffmpeg-linux-arm64.zip",
390
+ "debian13-x64": "builds/ffmpeg/%s/ffmpeg-linux.zip",
391
+ "debian13-arm64": "builds/ffmpeg/%s/ffmpeg-linux-arm64.zip",
392
+ "mac10.13": "builds/ffmpeg/%s/ffmpeg-mac.zip",
393
+ "mac10.14": "builds/ffmpeg/%s/ffmpeg-mac.zip",
394
+ "mac10.15": "builds/ffmpeg/%s/ffmpeg-mac.zip",
395
+ "mac11": "builds/ffmpeg/%s/ffmpeg-mac.zip",
396
+ "mac11-arm64": "builds/ffmpeg/%s/ffmpeg-mac-arm64.zip",
397
+ "mac12": "builds/ffmpeg/%s/ffmpeg-mac.zip",
398
+ "mac12-arm64": "builds/ffmpeg/%s/ffmpeg-mac-arm64.zip",
399
+ "mac13": "builds/ffmpeg/%s/ffmpeg-mac.zip",
400
+ "mac13-arm64": "builds/ffmpeg/%s/ffmpeg-mac-arm64.zip",
401
+ "mac14": "builds/ffmpeg/%s/ffmpeg-mac.zip",
402
+ "mac14-arm64": "builds/ffmpeg/%s/ffmpeg-mac-arm64.zip",
403
+ "mac15": "builds/ffmpeg/%s/ffmpeg-mac.zip",
404
+ "mac15-arm64": "builds/ffmpeg/%s/ffmpeg-mac-arm64.zip",
405
+ "win64": "builds/ffmpeg/%s/ffmpeg-win64.zip"
406
+ },
407
+ "winldd": {
408
+ "<unknown>": void 0,
409
+ "ubuntu18.04-x64": void 0,
410
+ "ubuntu20.04-x64": void 0,
411
+ "ubuntu22.04-x64": void 0,
412
+ "ubuntu24.04-x64": void 0,
413
+ "ubuntu18.04-arm64": void 0,
414
+ "ubuntu20.04-arm64": void 0,
415
+ "ubuntu22.04-arm64": void 0,
416
+ "ubuntu24.04-arm64": void 0,
417
+ "debian11-x64": void 0,
418
+ "debian11-arm64": void 0,
419
+ "debian12-x64": void 0,
420
+ "debian12-arm64": void 0,
421
+ "debian13-x64": void 0,
422
+ "debian13-arm64": void 0,
423
+ "mac10.13": void 0,
424
+ "mac10.14": void 0,
425
+ "mac10.15": void 0,
426
+ "mac11": void 0,
427
+ "mac11-arm64": void 0,
428
+ "mac12": void 0,
429
+ "mac12-arm64": void 0,
430
+ "mac13": void 0,
431
+ "mac13-arm64": void 0,
432
+ "mac14": void 0,
433
+ "mac14-arm64": void 0,
434
+ "mac15": void 0,
435
+ "mac15-arm64": void 0,
436
+ "win64": "builds/winldd/%s/winldd-win64.zip"
437
+ },
438
+ "android": {
439
+ "<unknown>": "builds/android/%s/android.zip",
440
+ "ubuntu18.04-x64": void 0,
441
+ "ubuntu20.04-x64": "builds/android/%s/android.zip",
442
+ "ubuntu22.04-x64": "builds/android/%s/android.zip",
443
+ "ubuntu24.04-x64": "builds/android/%s/android.zip",
444
+ "ubuntu18.04-arm64": void 0,
445
+ "ubuntu20.04-arm64": "builds/android/%s/android.zip",
446
+ "ubuntu22.04-arm64": "builds/android/%s/android.zip",
447
+ "ubuntu24.04-arm64": "builds/android/%s/android.zip",
448
+ "debian11-x64": "builds/android/%s/android.zip",
449
+ "debian11-arm64": "builds/android/%s/android.zip",
450
+ "debian12-x64": "builds/android/%s/android.zip",
451
+ "debian12-arm64": "builds/android/%s/android.zip",
452
+ "debian13-x64": "builds/android/%s/android.zip",
453
+ "debian13-arm64": "builds/android/%s/android.zip",
454
+ "mac10.13": "builds/android/%s/android.zip",
455
+ "mac10.14": "builds/android/%s/android.zip",
456
+ "mac10.15": "builds/android/%s/android.zip",
457
+ "mac11": "builds/android/%s/android.zip",
458
+ "mac11-arm64": "builds/android/%s/android.zip",
459
+ "mac12": "builds/android/%s/android.zip",
460
+ "mac12-arm64": "builds/android/%s/android.zip",
461
+ "mac13": "builds/android/%s/android.zip",
462
+ "mac13-arm64": "builds/android/%s/android.zip",
463
+ "mac14": "builds/android/%s/android.zip",
464
+ "mac14-arm64": "builds/android/%s/android.zip",
465
+ "mac15": "builds/android/%s/android.zip",
466
+ "mac15-arm64": "builds/android/%s/android.zip",
467
+ "win64": "builds/android/%s/android.zip"
468
+ }
469
+ };
470
+ const registryDirectory = (() => {
471
+ let result;
472
+ const envDefined = (0, import_utils.getFromENV)("PLAYWRIGHT_BROWSERS_PATH");
473
+ if (envDefined === "0") {
474
+ result = import_path.default.join(__dirname, "..", "..", "..", ".local-browsers");
475
+ } else if (envDefined) {
476
+ result = envDefined;
477
+ } else {
478
+ let cacheDirectory;
479
+ if (process.platform === "linux")
480
+ cacheDirectory = process.env.XDG_CACHE_HOME || import_path.default.join(import_os.default.homedir(), ".cache");
481
+ else if (process.platform === "darwin")
482
+ cacheDirectory = import_path.default.join(import_os.default.homedir(), "Library", "Caches");
483
+ else if (process.platform === "win32")
484
+ cacheDirectory = process.env.LOCALAPPDATA || import_path.default.join(import_os.default.homedir(), "AppData", "Local");
485
+ else
486
+ throw new Error("Unsupported platform: " + process.platform);
487
+ result = import_path.default.join(cacheDirectory, "ms-playwright");
488
+ }
489
+ if (!import_path.default.isAbsolute(result)) {
490
+ result = import_path.default.resolve((0, import_utils.getFromENV)("INIT_CWD") || process.cwd(), result);
491
+ }
492
+ return result;
493
+ })();
494
+ function isBrowserDirectory(browserDirectory) {
495
+ const baseName = import_path.default.basename(browserDirectory);
496
+ for (const browserName of allDownloadableDirectoriesThatEverExisted) {
497
+ if (baseName.startsWith(browserName.replace(/-/g, "_") + "-"))
498
+ return true;
499
+ }
500
+ return false;
501
+ }
502
+ function readDescriptors(browsersJSON) {
503
+ return browsersJSON["browsers"].map((obj) => {
504
+ const name = obj.name;
505
+ const revisionOverride = (obj.revisionOverrides || {})[import_hostPlatform.hostPlatform];
506
+ const revision = revisionOverride || obj.revision;
507
+ const browserDirectoryPrefix = revisionOverride ? `${name}_${import_hostPlatform.hostPlatform}_special` : `${name}`;
508
+ const descriptor = {
509
+ name,
510
+ revision,
511
+ hasRevisionOverride: !!revisionOverride,
512
+ // We only put browser version for the supported operating systems.
513
+ browserVersion: revisionOverride ? void 0 : obj.browserVersion,
514
+ title: obj["title"],
515
+ installByDefault: !!obj.installByDefault,
516
+ // Method `isBrowserDirectory` determines directory to be browser iff
517
+ // it starts with some browser name followed by '-'. Some browser names
518
+ // are prefixes of others, e.g. 'webkit' is a prefix of `webkit-technology-preview`.
519
+ // To avoid older registries erroneously removing 'webkit-technology-preview', we have to
520
+ // ensure that browser folders to never include dashes inside.
521
+ dir: import_path.default.join(registryDirectory, browserDirectoryPrefix.replace(/-/g, "_") + "-" + revision)
522
+ };
523
+ return descriptor;
524
+ });
525
+ }
526
+ const allDownloadableDirectoriesThatEverExisted = ["android", "chromium", "firefox", "webkit", "ffmpeg", "firefox-beta", "chromium-tip-of-tree", "chromium-headless-shell", "chromium-tip-of-tree-headless-shell", "winldd"];
527
+ const chromiumAliases = ["bidi-chromium", "chrome-for-testing"];
528
+ class Registry {
529
+ constructor(browsersJSON) {
530
+ const descriptors = readDescriptors(browsersJSON);
531
+ const findExecutablePath = (dir, name) => {
532
+ const tokens = EXECUTABLE_PATHS[name][import_hostPlatform.shortPlatform];
533
+ return tokens ? import_path.default.join(dir, ...tokens) : void 0;
534
+ };
535
+ const executablePathOrDie = (name, e, installByDefault, sdkLanguage) => {
536
+ if (!e)
537
+ throw new Error(`${name} is not supported on ${import_hostPlatform.hostPlatform}`);
538
+ const installCommand = buildPlaywrightCLICommand(sdkLanguage, `install${installByDefault ? "" : " " + name}`);
539
+ if (!(0, import_fileUtils.canAccessFile)(e)) {
540
+ const currentDockerVersion = (0, import_dependencies.readDockerVersionSync)();
541
+ const preferredDockerVersion = currentDockerVersion ? (0, import_dependencies.dockerVersion)(currentDockerVersion.dockerImageNameTemplate) : null;
542
+ const isOutdatedDockerImage = currentDockerVersion && preferredDockerVersion && currentDockerVersion.dockerImageName !== preferredDockerVersion.dockerImageName;
543
+ const prettyMessage = isOutdatedDockerImage ? [
544
+ `Looks like ${sdkLanguage === "javascript" ? "Playwright Test or " : ""}Playwright was just updated to ${preferredDockerVersion.driverVersion}.`,
545
+ `Please update docker image as well.`,
546
+ `- current: ${currentDockerVersion.dockerImageName}`,
547
+ `- required: ${preferredDockerVersion.dockerImageName}`,
548
+ ``,
549
+ `<3 Playwright Team`
550
+ ].join("\n") : [
551
+ `Looks like ${sdkLanguage === "javascript" ? "Playwright Test or " : ""}Playwright was just installed or updated.`,
552
+ `Please run the following command to download new browser${installByDefault ? "s" : ""}:`,
553
+ ``,
554
+ ` ${installCommand}`,
555
+ ``,
556
+ `<3 Playwright Team`
557
+ ].join("\n");
558
+ throw new Error(`Executable doesn't exist at ${e}
559
+ ${(0, import_ascii.wrapInASCIIBox)(prettyMessage, 1)}`);
560
+ }
561
+ return e;
562
+ };
563
+ this._executables = [];
564
+ const chromium = descriptors.find((d) => d.name === "chromium");
565
+ const chromiumExecutable = findExecutablePath(chromium.dir, "chromium");
566
+ this._executables.push({
567
+ name: "chromium",
568
+ browserName: "chromium",
569
+ directory: chromium.dir,
570
+ executablePath: () => chromiumExecutable,
571
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("chromium", chromiumExecutable, chromium.installByDefault, sdkLanguage),
572
+ installType: chromium.installByDefault ? "download-by-default" : "download-on-demand",
573
+ _validateHostRequirements: (sdkLanguage) => this._validateHostRequirements(sdkLanguage, chromium.dir, ["chrome-linux"], [], ["chrome-win"]),
574
+ downloadURLs: this._downloadURLs(chromium),
575
+ title: chromium.title,
576
+ revision: chromium.revision,
577
+ browserVersion: chromium.browserVersion,
578
+ _install: (force) => this._downloadExecutable(chromium, force, chromiumExecutable),
579
+ _dependencyGroup: "chromium",
580
+ _isHermeticInstallation: true
581
+ });
582
+ const chromiumHeadlessShell = descriptors.find((d) => d.name === "chromium-headless-shell");
583
+ const chromiumHeadlessShellExecutable = findExecutablePath(chromiumHeadlessShell.dir, "chromium-headless-shell");
584
+ this._executables.push({
585
+ name: "chromium-headless-shell",
586
+ browserName: "chromium",
587
+ directory: chromiumHeadlessShell.dir,
588
+ executablePath: () => chromiumHeadlessShellExecutable,
589
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("chromium", chromiumHeadlessShellExecutable, chromiumHeadlessShell.installByDefault, sdkLanguage),
590
+ installType: chromiumHeadlessShell.installByDefault ? "download-by-default" : "download-on-demand",
591
+ _validateHostRequirements: (sdkLanguage) => this._validateHostRequirements(sdkLanguage, chromiumHeadlessShell.dir, ["chrome-linux"], [], ["chrome-win"]),
592
+ downloadURLs: this._downloadURLs(chromiumHeadlessShell),
593
+ title: chromiumHeadlessShell.title,
594
+ revision: chromiumHeadlessShell.revision,
595
+ browserVersion: chromiumHeadlessShell.browserVersion,
596
+ _install: (force) => this._downloadExecutable(chromiumHeadlessShell, force, chromiumHeadlessShellExecutable),
597
+ _dependencyGroup: "chromium",
598
+ _isHermeticInstallation: true
599
+ });
600
+ const chromiumTipOfTreeHeadlessShell = descriptors.find((d) => d.name === "chromium-tip-of-tree-headless-shell");
601
+ const chromiumTipOfTreeHeadlessShellExecutable = findExecutablePath(chromiumTipOfTreeHeadlessShell.dir, "chromium-tip-of-tree-headless-shell");
602
+ this._executables.push({
603
+ name: "chromium-tip-of-tree-headless-shell",
604
+ browserName: "chromium",
605
+ directory: chromiumTipOfTreeHeadlessShell.dir,
606
+ executablePath: () => chromiumTipOfTreeHeadlessShellExecutable,
607
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("chromium", chromiumTipOfTreeHeadlessShellExecutable, chromiumTipOfTreeHeadlessShell.installByDefault, sdkLanguage),
608
+ installType: chromiumTipOfTreeHeadlessShell.installByDefault ? "download-by-default" : "download-on-demand",
609
+ _validateHostRequirements: (sdkLanguage) => this._validateHostRequirements(sdkLanguage, chromiumTipOfTreeHeadlessShell.dir, ["chrome-linux"], [], ["chrome-win"]),
610
+ downloadURLs: this._downloadURLs(chromiumTipOfTreeHeadlessShell),
611
+ title: chromiumTipOfTreeHeadlessShell.title,
612
+ revision: chromiumTipOfTreeHeadlessShell.revision,
613
+ browserVersion: chromiumTipOfTreeHeadlessShell.browserVersion,
614
+ _install: (force) => this._downloadExecutable(chromiumTipOfTreeHeadlessShell, force, chromiumTipOfTreeHeadlessShellExecutable),
615
+ _dependencyGroup: "chromium",
616
+ _isHermeticInstallation: true
617
+ });
618
+ const chromiumTipOfTree = descriptors.find((d) => d.name === "chromium-tip-of-tree");
619
+ const chromiumTipOfTreeExecutable = findExecutablePath(chromiumTipOfTree.dir, "chromium-tip-of-tree");
620
+ this._executables.push({
621
+ name: "chromium-tip-of-tree",
622
+ browserName: "chromium",
623
+ directory: chromiumTipOfTree.dir,
624
+ executablePath: () => chromiumTipOfTreeExecutable,
625
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("chromium-tip-of-tree", chromiumTipOfTreeExecutable, chromiumTipOfTree.installByDefault, sdkLanguage),
626
+ installType: chromiumTipOfTree.installByDefault ? "download-by-default" : "download-on-demand",
627
+ _validateHostRequirements: (sdkLanguage) => this._validateHostRequirements(sdkLanguage, chromiumTipOfTree.dir, ["chrome-linux"], [], ["chrome-win"]),
628
+ downloadURLs: this._downloadURLs(chromiumTipOfTree),
629
+ title: chromiumTipOfTree.title,
630
+ revision: chromiumTipOfTree.revision,
631
+ browserVersion: chromiumTipOfTree.browserVersion,
632
+ _install: (force) => this._downloadExecutable(chromiumTipOfTree, force, chromiumTipOfTreeExecutable),
633
+ _dependencyGroup: "chromium",
634
+ _isHermeticInstallation: true
635
+ });
636
+ this._executables.push(this._createChromiumChannel("chrome", {
637
+ "linux": "/opt/google/chrome/chrome",
638
+ "darwin": "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome",
639
+ "win32": `\\Google\\Chrome\\Application\\chrome.exe`
640
+ }, () => this._installChromiumChannel("chrome", {
641
+ "linux": "reinstall_chrome_stable_linux.sh",
642
+ "darwin": "reinstall_chrome_stable_mac.sh",
643
+ "win32": "reinstall_chrome_stable_win.ps1"
644
+ })));
645
+ this._executables.push(this._createChromiumChannel("chrome-beta", {
646
+ "linux": "/opt/google/chrome-beta/chrome",
647
+ "darwin": "/Applications/Google Chrome Beta.app/Contents/MacOS/Google Chrome Beta",
648
+ "win32": `\\Google\\Chrome Beta\\Application\\chrome.exe`
649
+ }, () => this._installChromiumChannel("chrome-beta", {
650
+ "linux": "reinstall_chrome_beta_linux.sh",
651
+ "darwin": "reinstall_chrome_beta_mac.sh",
652
+ "win32": "reinstall_chrome_beta_win.ps1"
653
+ })));
654
+ this._executables.push(this._createChromiumChannel("chrome-dev", {
655
+ "linux": "/opt/google/chrome-unstable/chrome",
656
+ "darwin": "/Applications/Google Chrome Dev.app/Contents/MacOS/Google Chrome Dev",
657
+ "win32": `\\Google\\Chrome Dev\\Application\\chrome.exe`
658
+ }));
659
+ this._executables.push(this._createChromiumChannel("chrome-canary", {
660
+ "linux": "/opt/google/chrome-canary/chrome",
661
+ "darwin": "/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary",
662
+ "win32": `\\Google\\Chrome SxS\\Application\\chrome.exe`
663
+ }));
664
+ this._executables.push(this._createChromiumChannel("msedge", {
665
+ "linux": "/opt/microsoft/msedge/msedge",
666
+ "darwin": "/Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge",
667
+ "win32": `\\Microsoft\\Edge\\Application\\msedge.exe`
668
+ }, () => this._installMSEdgeChannel("msedge", {
669
+ "linux": "reinstall_msedge_stable_linux.sh",
670
+ "darwin": "reinstall_msedge_stable_mac.sh",
671
+ "win32": "reinstall_msedge_stable_win.ps1"
672
+ })));
673
+ this._executables.push(this._createChromiumChannel("msedge-beta", {
674
+ "linux": "/opt/microsoft/msedge-beta/msedge",
675
+ "darwin": "/Applications/Microsoft Edge Beta.app/Contents/MacOS/Microsoft Edge Beta",
676
+ "win32": `\\Microsoft\\Edge Beta\\Application\\msedge.exe`
677
+ }, () => this._installMSEdgeChannel("msedge-beta", {
678
+ "darwin": "reinstall_msedge_beta_mac.sh",
679
+ "linux": "reinstall_msedge_beta_linux.sh",
680
+ "win32": "reinstall_msedge_beta_win.ps1"
681
+ })));
682
+ this._executables.push(this._createChromiumChannel("msedge-dev", {
683
+ "linux": "/opt/microsoft/msedge-dev/msedge",
684
+ "darwin": "/Applications/Microsoft Edge Dev.app/Contents/MacOS/Microsoft Edge Dev",
685
+ "win32": `\\Microsoft\\Edge Dev\\Application\\msedge.exe`
686
+ }, () => this._installMSEdgeChannel("msedge-dev", {
687
+ "darwin": "reinstall_msedge_dev_mac.sh",
688
+ "linux": "reinstall_msedge_dev_linux.sh",
689
+ "win32": "reinstall_msedge_dev_win.ps1"
690
+ })));
691
+ this._executables.push(this._createChromiumChannel("msedge-canary", {
692
+ "linux": "",
693
+ "darwin": "/Applications/Microsoft Edge Canary.app/Contents/MacOS/Microsoft Edge Canary",
694
+ "win32": `\\Microsoft\\Edge SxS\\Application\\msedge.exe`
695
+ }));
696
+ this._executables.push(this._createBidiFirefoxChannel("moz-firefox", {
697
+ "linux": "/snap/bin/firefox",
698
+ "darwin": "/Applications/Firefox.app/Contents/MacOS/firefox",
699
+ "win32": "\\Mozilla Firefox\\firefox.exe"
700
+ }));
701
+ this._executables.push(this._createBidiFirefoxChannel("moz-firefox-beta", {
702
+ "linux": "/opt/firefox-beta/firefox",
703
+ "darwin": "/Applications/Firefox.app/Contents/MacOS/firefox",
704
+ "win32": "\\Mozilla Firefox\\firefox.exe"
705
+ }));
706
+ this._executables.push(this._createBidiFirefoxChannel("moz-firefox-nightly", {
707
+ "linux": "/opt/firefox-nightly/firefox",
708
+ "darwin": "/Applications/Firefox Nightly.app/Contents/MacOS/firefox",
709
+ "win32": "\\Mozilla Firefox\\firefox.exe"
710
+ }));
711
+ this._executables.push(this._createBidiChromiumChannel("bidi-chrome-stable", {
712
+ "linux": "/opt/google/chrome/chrome",
713
+ "darwin": "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome",
714
+ "win32": `\\Google\\Chrome\\Application\\chrome.exe`
715
+ }));
716
+ this._executables.push(this._createBidiChromiumChannel("bidi-chrome-canary", {
717
+ "linux": "/opt/google/chrome-canary/chrome",
718
+ "darwin": "/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary",
719
+ "win32": `\\Google\\Chrome SxS\\Application\\chrome.exe`
720
+ }));
721
+ const firefox = descriptors.find((d) => d.name === "firefox");
722
+ const firefoxExecutable = findExecutablePath(firefox.dir, "firefox");
723
+ this._executables.push({
724
+ name: "firefox",
725
+ browserName: "firefox",
726
+ directory: firefox.dir,
727
+ executablePath: () => firefoxExecutable,
728
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("firefox", firefoxExecutable, firefox.installByDefault, sdkLanguage),
729
+ installType: firefox.installByDefault ? "download-by-default" : "download-on-demand",
730
+ _validateHostRequirements: (sdkLanguage) => this._validateHostRequirements(sdkLanguage, firefox.dir, ["firefox"], [], ["firefox"]),
731
+ downloadURLs: this._downloadURLs(firefox),
732
+ title: firefox.title,
733
+ revision: firefox.revision,
734
+ browserVersion: firefox.browserVersion,
735
+ _install: (force) => this._downloadExecutable(firefox, force, firefoxExecutable),
736
+ _dependencyGroup: "firefox",
737
+ _isHermeticInstallation: true
738
+ });
739
+ const firefoxBeta = descriptors.find((d) => d.name === "firefox-beta");
740
+ const firefoxBetaExecutable = findExecutablePath(firefoxBeta.dir, "firefox");
741
+ this._executables.push({
742
+ name: "firefox-beta",
743
+ browserName: "firefox",
744
+ directory: firefoxBeta.dir,
745
+ executablePath: () => firefoxBetaExecutable,
746
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("firefox-beta", firefoxBetaExecutable, firefoxBeta.installByDefault, sdkLanguage),
747
+ installType: firefoxBeta.installByDefault ? "download-by-default" : "download-on-demand",
748
+ _validateHostRequirements: (sdkLanguage) => this._validateHostRequirements(sdkLanguage, firefoxBeta.dir, ["firefox"], [], ["firefox"]),
749
+ downloadURLs: this._downloadURLs(firefoxBeta),
750
+ title: firefoxBeta.title,
751
+ revision: firefoxBeta.revision,
752
+ browserVersion: firefoxBeta.browserVersion,
753
+ _install: (force) => this._downloadExecutable(firefoxBeta, force, firefoxBetaExecutable),
754
+ _dependencyGroup: "firefox",
755
+ _isHermeticInstallation: true
756
+ });
757
+ const webkit = descriptors.find((d) => d.name === "webkit");
758
+ const webkitExecutable = findExecutablePath(webkit.dir, "webkit");
759
+ const webkitLinuxLddDirectories = [
760
+ import_path.default.join("minibrowser-gtk"),
761
+ import_path.default.join("minibrowser-gtk", "bin"),
762
+ import_path.default.join("minibrowser-gtk", "lib"),
763
+ import_path.default.join("minibrowser-gtk", "sys", "lib"),
764
+ import_path.default.join("minibrowser-wpe"),
765
+ import_path.default.join("minibrowser-wpe", "bin"),
766
+ import_path.default.join("minibrowser-wpe", "lib"),
767
+ import_path.default.join("minibrowser-wpe", "sys", "lib")
768
+ ];
769
+ this._executables.push({
770
+ name: "webkit",
771
+ browserName: "webkit",
772
+ directory: webkit.dir,
773
+ executablePath: () => webkitExecutable,
774
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("webkit", webkitExecutable, webkit.installByDefault, sdkLanguage),
775
+ installType: webkit.installByDefault ? "download-by-default" : "download-on-demand",
776
+ _validateHostRequirements: (sdkLanguage) => this._validateHostRequirements(sdkLanguage, webkit.dir, webkitLinuxLddDirectories, ["libGLESv2.so.2", "libx264.so"], [""]),
777
+ downloadURLs: this._downloadURLs(webkit),
778
+ title: webkit.title,
779
+ revision: webkit.revision,
780
+ browserVersion: webkit.browserVersion,
781
+ _install: (force) => this._downloadExecutable(webkit, force, webkitExecutable),
782
+ _dependencyGroup: "webkit",
783
+ _isHermeticInstallation: true
784
+ });
785
+ this._executables.push({
786
+ name: "webkit-wsl",
787
+ browserName: "webkit",
788
+ directory: webkit.dir,
789
+ executablePath: () => webkitExecutable,
790
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("webkit", webkitExecutable, webkit.installByDefault, sdkLanguage),
791
+ installType: "download-on-demand",
792
+ title: "Webkit in WSL",
793
+ _validateHostRequirements: (sdkLanguage) => Promise.resolve(),
794
+ _isHermeticInstallation: true,
795
+ _install: async () => {
796
+ if (process.platform !== "win32")
797
+ throw new Error(`WebKit via WSL is only supported on Windows`);
798
+ const script = import_path.default.join(BIN_PATH, "install_webkit_wsl.ps1");
799
+ const { code } = await (0, import_spawnAsync.spawnAsync)("powershell.exe", [
800
+ "-ExecutionPolicy",
801
+ "Bypass",
802
+ "-File",
803
+ script
804
+ ], {
805
+ stdio: "inherit"
806
+ });
807
+ if (code !== 0)
808
+ throw new Error(`Failed to install WebKit via WSL`);
809
+ }
810
+ });
811
+ const ffmpeg = descriptors.find((d) => d.name === "ffmpeg");
812
+ const ffmpegExecutable = findExecutablePath(ffmpeg.dir, "ffmpeg");
813
+ this._executables.push({
814
+ name: "ffmpeg",
815
+ browserName: void 0,
816
+ directory: ffmpeg.dir,
817
+ executablePath: () => ffmpegExecutable,
818
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("ffmpeg", ffmpegExecutable, ffmpeg.installByDefault, sdkLanguage),
819
+ installType: ffmpeg.installByDefault ? "download-by-default" : "download-on-demand",
820
+ _validateHostRequirements: () => Promise.resolve(),
821
+ downloadURLs: this._downloadURLs(ffmpeg),
822
+ title: ffmpeg.title,
823
+ revision: ffmpeg.revision,
824
+ _install: (force) => this._downloadExecutable(ffmpeg, force, ffmpegExecutable),
825
+ _dependencyGroup: "tools",
826
+ _isHermeticInstallation: true
827
+ });
828
+ const winldd = descriptors.find((d) => d.name === "winldd");
829
+ const winlddExecutable = findExecutablePath(winldd.dir, "winldd");
830
+ this._executables.push({
831
+ name: "winldd",
832
+ browserName: void 0,
833
+ directory: winldd.dir,
834
+ executablePath: () => winlddExecutable,
835
+ executablePathOrDie: (sdkLanguage) => executablePathOrDie("winldd", winlddExecutable, winldd.installByDefault, sdkLanguage),
836
+ installType: process.platform === "win32" ? "download-by-default" : "none",
837
+ _validateHostRequirements: () => Promise.resolve(),
838
+ downloadURLs: this._downloadURLs(winldd),
839
+ title: winldd.title,
840
+ revision: winldd.revision,
841
+ _install: (force) => this._downloadExecutable(winldd, force, winlddExecutable),
842
+ _dependencyGroup: "tools",
843
+ _isHermeticInstallation: true
844
+ });
845
+ const android = descriptors.find((d) => d.name === "android");
846
+ this._executables.push({
847
+ name: "android",
848
+ browserName: void 0,
849
+ directory: android.dir,
850
+ executablePath: () => void 0,
851
+ executablePathOrDie: () => "",
852
+ installType: "download-on-demand",
853
+ _validateHostRequirements: () => Promise.resolve(),
854
+ downloadURLs: this._downloadURLs(android),
855
+ title: android.title,
856
+ revision: android.revision,
857
+ _install: (force) => this._downloadExecutable(android, force),
858
+ _dependencyGroup: "tools",
859
+ _isHermeticInstallation: true
860
+ });
861
+ }
862
+ _createChromiumChannel(name, lookAt, install) {
863
+ const executablePath = (sdkLanguage, shouldThrow) => {
864
+ const suffix = lookAt[process.platform];
865
+ if (!suffix) {
866
+ if (shouldThrow)
867
+ throw new Error(`Chromium distribution '${name}' is not supported on ${process.platform}`);
868
+ return void 0;
869
+ }
870
+ const prefixes = process.platform === "win32" ? [
871
+ process.env.LOCALAPPDATA,
872
+ process.env.PROGRAMFILES,
873
+ process.env["PROGRAMFILES(X86)"],
874
+ // In some cases there is no PROGRAMFILES/(86) env var set but HOMEDRIVE is set.
875
+ process.env.HOMEDRIVE + "\\Program Files",
876
+ process.env.HOMEDRIVE + "\\Program Files (x86)"
877
+ ].filter(Boolean) : [""];
878
+ for (const prefix of prefixes) {
879
+ const executablePath2 = import_path.default.join(prefix, suffix);
880
+ if ((0, import_fileUtils.canAccessFile)(executablePath2))
881
+ return executablePath2;
882
+ }
883
+ if (!shouldThrow)
884
+ return void 0;
885
+ const location = prefixes.length ? ` at ${import_path.default.join(prefixes[0], suffix)}` : ``;
886
+ const installation = install ? `
887
+ Run "${buildPlaywrightCLICommand(sdkLanguage, "install " + name)}"` : "";
888
+ throw new Error(`Chromium distribution '${name}' is not found${location}${installation}`);
889
+ };
890
+ return {
891
+ name,
892
+ browserName: "chromium",
893
+ directory: void 0,
894
+ executablePath: (sdkLanguage) => executablePath(sdkLanguage, false),
895
+ executablePathOrDie: (sdkLanguage) => executablePath(sdkLanguage, true),
896
+ installType: install ? "install-script" : "none",
897
+ _validateHostRequirements: () => Promise.resolve(),
898
+ _isHermeticInstallation: false,
899
+ _install: install
900
+ };
901
+ }
902
+ _createBidiFirefoxChannel(name, lookAt, install) {
903
+ const executablePath = (sdkLanguage, shouldThrow) => {
904
+ const suffix = lookAt[process.platform];
905
+ if (!suffix) {
906
+ if (shouldThrow)
907
+ throw new Error(`Firefox distribution '${name}' is not supported on ${process.platform}`);
908
+ return void 0;
909
+ }
910
+ const prefixes = process.platform === "win32" ? [
911
+ process.env.LOCALAPPDATA,
912
+ process.env.PROGRAMFILES,
913
+ process.env["PROGRAMFILES(X86)"],
914
+ // In some cases there is no PROGRAMFILES/(86) env var set but HOMEDRIVE is set.
915
+ process.env.HOMEDRIVE + "\\Program Files",
916
+ process.env.HOMEDRIVE + "\\Program Files (x86)"
917
+ ].filter(Boolean) : [""];
918
+ for (const prefix of prefixes) {
919
+ const executablePath2 = import_path.default.join(prefix, suffix);
920
+ if ((0, import_fileUtils.canAccessFile)(executablePath2))
921
+ return executablePath2;
922
+ }
923
+ if (shouldThrow)
924
+ throw new Error(`Cannot find Firefox installation for channel '${name}' at the standard system paths. ${`Tried paths:
925
+ ${prefixes.map((p) => import_path.default.join(p, suffix)).join("\n ")}`}`);
926
+ return void 0;
927
+ };
928
+ return {
929
+ name,
930
+ browserName: "firefox",
931
+ directory: void 0,
932
+ executablePath: (sdkLanguage) => executablePath(sdkLanguage, false),
933
+ executablePathOrDie: (sdkLanguage) => executablePath(sdkLanguage, true),
934
+ installType: "none",
935
+ _validateHostRequirements: () => Promise.resolve(),
936
+ _isHermeticInstallation: true,
937
+ _install: install
938
+ };
939
+ }
940
+ _createBidiChromiumChannel(name, lookAt) {
941
+ const executablePath = (sdkLanguage, shouldThrow) => {
942
+ const suffix = lookAt[process.platform];
943
+ if (!suffix) {
944
+ if (shouldThrow)
945
+ throw new Error(`Chromium distribution '${name}' is not supported on ${process.platform}`);
946
+ return void 0;
947
+ }
948
+ const prefixes = process.platform === "win32" ? [
949
+ process.env.LOCALAPPDATA,
950
+ process.env.PROGRAMFILES,
951
+ process.env["PROGRAMFILES(X86)"],
952
+ // In some cases there is no PROGRAMFILES/(86) env var set but HOMEDRIVE is set.
953
+ process.env.HOMEDRIVE + "\\Program Files",
954
+ process.env.HOMEDRIVE + "\\Program Files (x86)"
955
+ ].filter(Boolean) : [""];
956
+ for (const prefix of prefixes) {
957
+ const executablePath2 = import_path.default.join(prefix, suffix);
958
+ if ((0, import_fileUtils.canAccessFile)(executablePath2))
959
+ return executablePath2;
960
+ }
961
+ if (!shouldThrow)
962
+ return void 0;
963
+ const location = prefixes.length ? ` at ${import_path.default.join(prefixes[0], suffix)}` : ``;
964
+ throw new Error(`Chromium distribution '${name}' is not found${location}`);
965
+ };
966
+ return {
967
+ name,
968
+ browserName: "chromium",
969
+ directory: void 0,
970
+ executablePath: (sdkLanguage) => executablePath(sdkLanguage, false),
971
+ executablePathOrDie: (sdkLanguage) => executablePath(sdkLanguage, true),
972
+ installType: "none",
973
+ _validateHostRequirements: () => Promise.resolve(),
974
+ _isHermeticInstallation: false
975
+ };
976
+ }
977
+ executables() {
978
+ return this._executables;
979
+ }
980
+ findExecutable(name) {
981
+ return this._executables.find((b) => b.name === name);
982
+ }
983
+ defaultExecutables() {
984
+ return this._executables.filter((e) => e.installType === "download-by-default");
985
+ }
986
+ _dedupe(executables) {
987
+ return Array.from(new Set(executables));
988
+ }
989
+ async _validateHostRequirements(sdkLanguage, browserDirectory, linuxLddDirectories, dlOpenLibraries, windowsExeAndDllDirectories) {
990
+ if (import_os.default.platform() === "linux")
991
+ return await (0, import_dependencies2.validateDependenciesLinux)(sdkLanguage, linuxLddDirectories.map((d) => import_path.default.join(browserDirectory, d)), dlOpenLibraries);
992
+ if (import_os.default.platform() === "win32" && import_os.default.arch() === "x64")
993
+ return await (0, import_dependencies2.validateDependenciesWindows)(sdkLanguage, windowsExeAndDllDirectories.map((d) => import_path.default.join(browserDirectory, d)));
994
+ }
995
+ async installDeps(executablesToInstallDeps, dryRun) {
996
+ const executables = this._dedupe(executablesToInstallDeps);
997
+ const targets = /* @__PURE__ */ new Set();
998
+ for (const executable of executables) {
999
+ if (executable._dependencyGroup)
1000
+ targets.add(executable._dependencyGroup);
1001
+ }
1002
+ targets.add("tools");
1003
+ if (import_os.default.platform() === "win32")
1004
+ return await (0, import_dependencies2.installDependenciesWindows)(targets, dryRun);
1005
+ if (import_os.default.platform() === "linux")
1006
+ return await (0, import_dependencies2.installDependenciesLinux)(targets, dryRun);
1007
+ }
1008
+ async install(executablesToInstall, options) {
1009
+ const executables = this._dedupe(executablesToInstall);
1010
+ await import_fs.default.promises.mkdir(registryDirectory, { recursive: true });
1011
+ const lockfilePath = import_path.default.join(registryDirectory, "__dirlock");
1012
+ const linksDir = import_path.default.join(registryDirectory, ".links");
1013
+ let releaseLock;
1014
+ try {
1015
+ releaseLock = await import_utilsBundle.lockfile.lock(registryDirectory, {
1016
+ retries: {
1017
+ // Retry 20 times during 10 minutes with
1018
+ // exponential back-off.
1019
+ // See documentation at: https://www.npmjs.com/package/retry#retrytimeoutsoptions
1020
+ retries: 20,
1021
+ factor: 1.27579
1022
+ },
1023
+ onCompromised: (err) => {
1024
+ throw new Error(`${err.message} Path: ${lockfilePath}`);
1025
+ },
1026
+ lockfilePath
1027
+ });
1028
+ await import_fs.default.promises.mkdir(linksDir, { recursive: true });
1029
+ await import_fs.default.promises.writeFile(import_path.default.join(linksDir, (0, import_utils.calculateSha1)(PACKAGE_PATH)), PACKAGE_PATH);
1030
+ if (!(0, import_utils.getAsBooleanFromENV)("PLAYWRIGHT_SKIP_BROWSER_GC"))
1031
+ await this._validateInstallationCache(linksDir);
1032
+ for (const executable of executables) {
1033
+ if (!executable._install)
1034
+ throw new Error(`ERROR: Playwright does not support installing ${executable.name}`);
1035
+ const { embedderName } = (0, import_userAgent.getEmbedderName)();
1036
+ if (!(0, import_utils.getAsBooleanFromENV)("CI") && !executable._isHermeticInstallation && !options?.force && executable.executablePath(embedderName)) {
1037
+ const command = buildPlaywrightCLICommand(embedderName, "install --force " + executable.name);
1038
+ process.stderr.write("\n" + (0, import_ascii.wrapInASCIIBox)([
1039
+ `ATTENTION: "${executable.name}" is already installed on the system!`,
1040
+ ``,
1041
+ `"${executable.name}" installation is not hermetic; installing newer version`,
1042
+ `requires *removal* of a current installation first.`,
1043
+ ``,
1044
+ `To *uninstall* current version and re-install latest "${executable.name}":`,
1045
+ ``,
1046
+ `- Close all running instances of "${executable.name}", if any`,
1047
+ `- Use "--force" to install browser:`,
1048
+ ``,
1049
+ ` ${command}`,
1050
+ ``,
1051
+ `<3 Playwright Team`
1052
+ ].join("\n"), 1) + "\n\n");
1053
+ return;
1054
+ }
1055
+ await executable._install(!!options?.force);
1056
+ }
1057
+ } catch (e) {
1058
+ if (e.code === "ELOCKED") {
1059
+ const rmCommand = process.platform === "win32" ? "rm -R" : "rm -rf";
1060
+ throw new Error("\n" + (0, import_ascii.wrapInASCIIBox)([
1061
+ `An active lockfile is found at:`,
1062
+ ``,
1063
+ ` ${lockfilePath}`,
1064
+ ``,
1065
+ `Either:`,
1066
+ `- wait a few minutes if other Playwright is installing browsers in parallel`,
1067
+ `- remove lock manually with:`,
1068
+ ``,
1069
+ ` ${rmCommand} ${lockfilePath}`,
1070
+ ``,
1071
+ `<3 Playwright Team`
1072
+ ].join("\n"), 1));
1073
+ } else {
1074
+ throw e;
1075
+ }
1076
+ } finally {
1077
+ if (releaseLock)
1078
+ await releaseLock();
1079
+ }
1080
+ }
1081
+ async uninstall(all) {
1082
+ const linksDir = import_path.default.join(registryDirectory, ".links");
1083
+ if (all) {
1084
+ const links = await import_fs.default.promises.readdir(linksDir).catch(() => []);
1085
+ for (const link of links)
1086
+ await import_fs.default.promises.unlink(import_path.default.join(linksDir, link));
1087
+ } else {
1088
+ await import_fs.default.promises.unlink(import_path.default.join(linksDir, (0, import_utils.calculateSha1)(PACKAGE_PATH))).catch(() => {
1089
+ });
1090
+ }
1091
+ await this._validateInstallationCache(linksDir);
1092
+ return {
1093
+ numberOfBrowsersLeft: (await import_fs.default.promises.readdir(registryDirectory).catch(() => [])).filter((browserDirectory) => isBrowserDirectory(browserDirectory)).length
1094
+ };
1095
+ }
1096
+ async validateHostRequirementsForExecutablesIfNeeded(executables, sdkLanguage) {
1097
+ if ((0, import_utils.getAsBooleanFromENV)("PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS")) {
1098
+ process.stderr.write("Skipping host requirements validation logic because `PLAYWRIGHT_SKIP_VALIDATE_HOST_REQUIREMENTS` env variable is set.\n");
1099
+ return;
1100
+ }
1101
+ for (const executable of executables)
1102
+ await this._validateHostRequirementsForExecutableIfNeeded(executable, sdkLanguage);
1103
+ }
1104
+ async _validateHostRequirementsForExecutableIfNeeded(executable, sdkLanguage) {
1105
+ const kMaximumReValidationPeriod = 30 * 24 * 60 * 60 * 1e3;
1106
+ if (!executable.directory)
1107
+ return;
1108
+ const markerFile = import_path.default.join(executable.directory, "DEPENDENCIES_VALIDATED");
1109
+ if (await import_fs.default.promises.stat(markerFile).then((stat) => Date.now() - stat.mtime.getTime() < kMaximumReValidationPeriod).catch(() => false))
1110
+ return;
1111
+ import_debugLogger.debugLogger.log("install", `validating host requirements for "${executable.name}"`);
1112
+ try {
1113
+ await executable._validateHostRequirements(sdkLanguage);
1114
+ import_debugLogger.debugLogger.log("install", `validation passed for ${executable.name}`);
1115
+ } catch (error) {
1116
+ import_debugLogger.debugLogger.log("install", `validation failed for ${executable.name}`);
1117
+ throw error;
1118
+ }
1119
+ await import_fs.default.promises.writeFile(markerFile, "").catch(() => {
1120
+ });
1121
+ }
1122
+ _downloadURLs(descriptor) {
1123
+ const paths = DOWNLOAD_PATHS[descriptor.name];
1124
+ const downloadPathTemplate = paths[import_hostPlatform.hostPlatform] || paths["<unknown>"];
1125
+ if (!downloadPathTemplate)
1126
+ return [];
1127
+ let downloadPath;
1128
+ let mirrors;
1129
+ if (typeof downloadPathTemplate === "function") {
1130
+ const result = downloadPathTemplate(descriptor);
1131
+ downloadPath = result.path;
1132
+ mirrors = result.mirrors;
1133
+ } else {
1134
+ downloadPath = util.format(downloadPathTemplate, descriptor.revision);
1135
+ mirrors = PLAYWRIGHT_CDN_MIRRORS;
1136
+ }
1137
+ let downloadHostEnv;
1138
+ if (descriptor.name.startsWith("chromium"))
1139
+ downloadHostEnv = "PLAYWRIGHT_CHROMIUM_DOWNLOAD_HOST";
1140
+ else if (descriptor.name.startsWith("firefox"))
1141
+ downloadHostEnv = "PLAYWRIGHT_FIREFOX_DOWNLOAD_HOST";
1142
+ else if (descriptor.name.startsWith("webkit"))
1143
+ downloadHostEnv = "PLAYWRIGHT_WEBKIT_DOWNLOAD_HOST";
1144
+ const customHostOverride = downloadHostEnv && (0, import_utils.getFromENV)(downloadHostEnv) || (0, import_utils.getFromENV)("PLAYWRIGHT_DOWNLOAD_HOST");
1145
+ if (customHostOverride)
1146
+ mirrors = [customHostOverride];
1147
+ return mirrors.map((mirror) => `${mirror}/${downloadPath}`);
1148
+ }
1149
+ async _downloadExecutable(descriptor, force, executablePath) {
1150
+ const downloadURLs = this._downloadURLs(descriptor);
1151
+ if (!downloadURLs.length)
1152
+ throw new Error(`ERROR: Playwright does not support ${descriptor.name} on ${import_hostPlatform.hostPlatform}`);
1153
+ if (!import_hostPlatform.isOfficiallySupportedPlatform)
1154
+ (0, import_browserFetcher.logPolitely)(`BEWARE: your OS is not officially supported by Playwright; downloading fallback build for ${import_hostPlatform.hostPlatform}.`);
1155
+ if (descriptor.hasRevisionOverride) {
1156
+ const message = `You are using a frozen ${descriptor.name} browser which does not receive updates anymore on ${import_hostPlatform.hostPlatform}. Please update to the latest version of your operating system to test up-to-date browsers.`;
1157
+ if (process.env.GITHUB_ACTIONS)
1158
+ console.log(`::warning title=Playwright::${message}`);
1159
+ else
1160
+ (0, import_browserFetcher.logPolitely)(message);
1161
+ }
1162
+ const title = this.calculateDownloadTitle(descriptor);
1163
+ const downloadFileName = `playwright-download-${descriptor.name}-${import_hostPlatform.hostPlatform}-${descriptor.revision}.zip`;
1164
+ const downloadSocketTimeoutEnv = (0, import_utils.getFromENV)("PLAYWRIGHT_DOWNLOAD_CONNECTION_TIMEOUT");
1165
+ const downloadSocketTimeout = +(downloadSocketTimeoutEnv || "0") || import_network.NET_DEFAULT_TIMEOUT;
1166
+ await (0, import_browserFetcher.downloadBrowserWithProgressBar)(title, descriptor.dir, executablePath, downloadURLs, downloadFileName, downloadSocketTimeout, force).catch((e) => {
1167
+ throw new Error(`Failed to download ${title}, caused by
1168
+ ${e.stack}`);
1169
+ });
1170
+ }
1171
+ calculateDownloadTitle(descriptor) {
1172
+ const title = descriptor.title ?? descriptor.name.split("-").map((word) => {
1173
+ return word === "ffmpeg" ? "FFmpeg" : word.charAt(0).toUpperCase() + word.slice(1);
1174
+ }).join(" ");
1175
+ const version = descriptor.browserVersion ? " " + descriptor.browserVersion : "";
1176
+ return `${title}${version} (playwright ${descriptor.name} v${descriptor.revision})`;
1177
+ }
1178
+ async _installMSEdgeChannel(channel, scripts) {
1179
+ const scriptArgs = [];
1180
+ if (process.platform !== "linux") {
1181
+ const products = lowercaseAllKeys(JSON.parse(await (0, import_network.fetchData)(void 0, { url: "https://edgeupdates.microsoft.com/api/products" })));
1182
+ const productName = {
1183
+ "msedge": "Stable",
1184
+ "msedge-beta": "Beta",
1185
+ "msedge-dev": "Dev"
1186
+ }[channel];
1187
+ const product = products.find((product2) => product2.product === productName);
1188
+ const searchConfig = {
1189
+ darwin: { platform: "MacOS", arch: "universal", artifact: "pkg" },
1190
+ win32: { platform: "Windows", arch: "x64", artifact: "msi" }
1191
+ }[process.platform];
1192
+ const release = searchConfig ? product.releases.find((release2) => release2.platform === searchConfig.platform && release2.architecture === searchConfig.arch && release2.artifacts.length > 0) : null;
1193
+ const artifact = release ? release.artifacts.find((artifact2) => artifact2.artifactname === searchConfig.artifact) : null;
1194
+ if (artifact)
1195
+ scriptArgs.push(
1196
+ artifact.location
1197
+ /* url */
1198
+ );
1199
+ else
1200
+ throw new Error(`Cannot install ${channel} on ${process.platform}`);
1201
+ }
1202
+ await this._installChromiumChannel(channel, scripts, scriptArgs);
1203
+ }
1204
+ async _installChromiumChannel(channel, scripts, scriptArgs = []) {
1205
+ const scriptName = scripts[process.platform];
1206
+ if (!scriptName)
1207
+ throw new Error(`Cannot install ${channel} on ${process.platform}`);
1208
+ const cwd = BIN_PATH;
1209
+ const isPowerShell = scriptName.endsWith(".ps1");
1210
+ if (isPowerShell) {
1211
+ const args = [
1212
+ "-ExecutionPolicy",
1213
+ "Bypass",
1214
+ "-File",
1215
+ import_path.default.join(BIN_PATH, scriptName),
1216
+ ...scriptArgs
1217
+ ];
1218
+ const { code } = await (0, import_spawnAsync.spawnAsync)("powershell.exe", args, { cwd, stdio: "inherit" });
1219
+ if (code !== 0)
1220
+ throw new Error(`Failed to install ${channel}`);
1221
+ } else {
1222
+ const { command, args, elevatedPermissions } = await (0, import_dependencies.transformCommandsForRoot)([`bash "${import_path.default.join(BIN_PATH, scriptName)}" ${scriptArgs.join("")}`]);
1223
+ if (elevatedPermissions)
1224
+ console.log("Switching to root user to install dependencies...");
1225
+ const { code } = await (0, import_spawnAsync.spawnAsync)(command, args, { cwd, stdio: "inherit" });
1226
+ if (code !== 0)
1227
+ throw new Error(`Failed to install ${channel}`);
1228
+ }
1229
+ }
1230
+ async listInstalledBrowsers() {
1231
+ const linksDir = import_path.default.join(registryDirectory, ".links");
1232
+ const { browsers } = await this._traverseBrowserInstallations(linksDir);
1233
+ return browsers.filter((browser) => import_fs.default.existsSync(browser.browserPath));
1234
+ }
1235
+ async _validateInstallationCache(linksDir) {
1236
+ const { browsers, brokenLinks } = await this._traverseBrowserInstallations(linksDir);
1237
+ await this._deleteStaleBrowsers(browsers);
1238
+ await this._deleteBrokenInstallations(brokenLinks);
1239
+ }
1240
+ async _traverseBrowserInstallations(linksDir) {
1241
+ const browserList = [];
1242
+ const brokenLinks = [];
1243
+ for (const fileName of await import_fs.default.promises.readdir(linksDir)) {
1244
+ const linkPath = import_path.default.join(linksDir, fileName);
1245
+ let linkTarget = "";
1246
+ try {
1247
+ linkTarget = (await import_fs.default.promises.readFile(linkPath)).toString();
1248
+ const browsersJSON = require(import_path.default.join(linkTarget, "browsers.json"));
1249
+ const descriptors = readDescriptors(browsersJSON);
1250
+ for (const browserName of allDownloadableDirectoriesThatEverExisted) {
1251
+ const descriptor = descriptors.find((d) => d.name === browserName);
1252
+ if (!descriptor)
1253
+ continue;
1254
+ const browserPath = descriptor.dir;
1255
+ const browserVersion = parseInt(descriptor.revision, 10);
1256
+ browserList.push({
1257
+ browserName,
1258
+ browserVersion,
1259
+ browserPath,
1260
+ referenceDir: linkTarget
1261
+ });
1262
+ }
1263
+ } catch (e) {
1264
+ brokenLinks.push(linkPath);
1265
+ }
1266
+ }
1267
+ return { browsers: browserList, brokenLinks };
1268
+ }
1269
+ async _deleteStaleBrowsers(browserList) {
1270
+ const usedBrowserPaths = /* @__PURE__ */ new Set();
1271
+ for (const browser of browserList) {
1272
+ const { browserName, browserVersion, browserPath } = browser;
1273
+ const shouldHaveMarkerFile = browserName === "chromium" && (browserVersion >= 786218 || browserVersion < 3e5) || browserName === "firefox" && browserVersion >= 1128 || browserName === "webkit" && browserVersion >= 1307 || // All new applications have a marker file right away.
1274
+ browserName !== "firefox" && browserName !== "chromium" && browserName !== "webkit";
1275
+ if (!shouldHaveMarkerFile || await (0, import_fileUtils.existsAsync)(browserDirectoryToMarkerFilePath(browserPath)))
1276
+ usedBrowserPaths.add(browserPath);
1277
+ }
1278
+ let downloadedBrowsers = (await import_fs.default.promises.readdir(registryDirectory)).map((file) => import_path.default.join(registryDirectory, file));
1279
+ downloadedBrowsers = downloadedBrowsers.filter((file) => isBrowserDirectory(file));
1280
+ const directories = new Set(downloadedBrowsers);
1281
+ for (const browserDirectory of usedBrowserPaths)
1282
+ directories.delete(browserDirectory);
1283
+ for (const directory of directories)
1284
+ (0, import_browserFetcher.logPolitely)("Removing unused browser at " + directory);
1285
+ await (0, import_fileUtils.removeFolders)([...directories]);
1286
+ }
1287
+ async _deleteBrokenInstallations(brokenLinks) {
1288
+ for (const linkPath of brokenLinks)
1289
+ await import_fs.default.promises.unlink(linkPath).catch((e) => {
1290
+ });
1291
+ }
1292
+ _defaultBrowsersToInstall(options) {
1293
+ let executables = this.defaultExecutables();
1294
+ if (options.shell === "no")
1295
+ executables = executables.filter((e) => e.name !== "chromium-headless-shell" && e.name !== "chromium-tip-of-tree-headless-shell");
1296
+ if (options.shell === "only")
1297
+ executables = executables.filter((e) => e.name !== "chromium" && e.name !== "chromium-tip-of-tree");
1298
+ return executables;
1299
+ }
1300
+ suggestedBrowsersToInstall() {
1301
+ const names = this.executables().filter((e) => e.installType !== "none").map((e) => e.name);
1302
+ names.push(...chromiumAliases);
1303
+ return names.sort().join(", ");
1304
+ }
1305
+ isChromiumAlias(name) {
1306
+ return chromiumAliases.includes(name);
1307
+ }
1308
+ resolveBrowsers(aliases, options) {
1309
+ if (aliases.length === 0)
1310
+ return this._defaultBrowsersToInstall(options);
1311
+ const faultyArguments = [];
1312
+ const executables = [];
1313
+ const handleArgument = (arg) => {
1314
+ const executable = this.findExecutable(arg);
1315
+ if (!executable || executable.installType === "none")
1316
+ faultyArguments.push(arg);
1317
+ else
1318
+ executables.push(executable);
1319
+ if (executable?.browserName)
1320
+ executables.push(this.findExecutable("ffmpeg"));
1321
+ };
1322
+ for (const alias of aliases) {
1323
+ if (alias === "chromium" || chromiumAliases.includes(alias)) {
1324
+ if (options.shell !== "only")
1325
+ handleArgument("chromium");
1326
+ if (options.shell !== "no")
1327
+ handleArgument("chromium-headless-shell");
1328
+ } else if (alias === "chromium-tip-of-tree") {
1329
+ if (options.shell !== "only")
1330
+ handleArgument("chromium-tip-of-tree");
1331
+ if (options.shell !== "no")
1332
+ handleArgument("chromium-tip-of-tree-headless-shell");
1333
+ } else {
1334
+ handleArgument(alias);
1335
+ }
1336
+ }
1337
+ if (process.platform === "win32")
1338
+ executables.push(this.findExecutable("winldd"));
1339
+ if (faultyArguments.length)
1340
+ throw new Error(`Invalid installation targets: ${faultyArguments.map((name) => `'${name}'`).join(", ")}. Expecting one of: ${this.suggestedBrowsersToInstall()}`);
1341
+ return executables;
1342
+ }
1343
+ }
1344
+ function browserDirectoryToMarkerFilePath(browserDirectory) {
1345
+ return import_path.default.join(browserDirectory, "INSTALLATION_COMPLETE");
1346
+ }
1347
+ function buildPlaywrightCLICommand(sdkLanguage, parameters) {
1348
+ switch (sdkLanguage) {
1349
+ case "python":
1350
+ return `playwright ${parameters}`;
1351
+ case "java":
1352
+ return `mvn exec:java -e -D exec.mainClass=com.microsoft.playwright.CLI -D exec.args="${parameters}"`;
1353
+ case "csharp":
1354
+ return `pwsh bin/Debug/netX/playwright.ps1 ${parameters}`;
1355
+ default: {
1356
+ const packageManagerCommand = (0, import_utils.getPackageManagerExecCommand)();
1357
+ return `${packageManagerCommand} playwright ${parameters}`;
1358
+ }
1359
+ }
1360
+ }
1361
+ async function installBrowsersForNpmInstall(browsers) {
1362
+ if ((0, import_utils.getAsBooleanFromENV)("PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD")) {
1363
+ (0, import_browserFetcher.logPolitely)("Skipping browsers download because `PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD` env variable is set");
1364
+ return false;
1365
+ }
1366
+ const executables = [];
1367
+ if (process.platform === "win32")
1368
+ executables.push(registry.findExecutable("winldd"));
1369
+ for (const browserName of browsers) {
1370
+ const executable = registry.findExecutable(browserName);
1371
+ if (!executable || executable.installType === "none")
1372
+ throw new Error(`Cannot install ${browserName}`);
1373
+ executables.push(executable);
1374
+ }
1375
+ await registry.install(executables);
1376
+ }
1377
+ function findChromiumChannelBestEffort(sdkLanguage) {
1378
+ let channel = null;
1379
+ for (const name of ["chromium", "chrome", "msedge"]) {
1380
+ try {
1381
+ registry.findExecutable(name).executablePathOrDie(sdkLanguage);
1382
+ channel = name === "chromium" ? void 0 : name;
1383
+ break;
1384
+ } catch (e) {
1385
+ }
1386
+ }
1387
+ if (channel === null) {
1388
+ const installCommand = buildPlaywrightCLICommand(sdkLanguage, `install chromium`);
1389
+ const prettyMessage = [
1390
+ `No chromium-based browser found on the system.`,
1391
+ `Please run the following command to download one:`,
1392
+ ``,
1393
+ ` ${installCommand}`,
1394
+ ``,
1395
+ `<3 Playwright Team`
1396
+ ].join("\n");
1397
+ throw new Error("\n" + (0, import_ascii.wrapInASCIIBox)(prettyMessage, 1));
1398
+ }
1399
+ return channel;
1400
+ }
1401
+ function lowercaseAllKeys(json) {
1402
+ if (typeof json !== "object" || !json)
1403
+ return json;
1404
+ if (Array.isArray(json))
1405
+ return json.map(lowercaseAllKeys);
1406
+ const result = {};
1407
+ for (const [key, value] of Object.entries(json))
1408
+ result[key.toLowerCase()] = lowercaseAllKeys(value);
1409
+ return result;
1410
+ }
1411
+ const registry = new Registry(require("../../../browsers.json"));
1412
+ // Annotate the CommonJS export names for ESM import in node:
1413
+ 0 && (module.exports = {
1414
+ Registry,
1415
+ browserDirectoryToMarkerFilePath,
1416
+ buildPlaywrightCLICommand,
1417
+ findChromiumChannelBestEffort,
1418
+ installBrowsersForNpmInstall,
1419
+ registry,
1420
+ registryDirectory,
1421
+ writeDockerVersion
1422
+ });