phantomwright-driver-core 1.57.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (333) hide show
  1. package/README.md +3 -0
  2. package/ThirdPartyNotices.txt +1161 -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 +80 -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 +590 -0
  29. package/lib/cli/programWithTestStub.js +74 -0
  30. package/lib/client/android.js +361 -0
  31. package/lib/client/api.js +134 -0
  32. package/lib/client/artifact.js +79 -0
  33. package/lib/client/browser.js +163 -0
  34. package/lib/client/browserContext.js +547 -0
  35. package/lib/client/browserType.js +184 -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 +314 -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 +281 -0
  49. package/lib/client/errors.js +77 -0
  50. package/lib/client/eventEmitter.js +314 -0
  51. package/lib/client/events.js +100 -0
  52. package/lib/client/fetch.js +369 -0
  53. package/lib/client/fileChooser.js +46 -0
  54. package/lib/client/fileUtils.js +34 -0
  55. package/lib/client/frame.js +408 -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 +718 -0
  64. package/lib/client/platform.js +74 -0
  65. package/lib/client/playwright.js +71 -0
  66. package/lib/client/selectors.js +55 -0
  67. package/lib/client/stream.js +39 -0
  68. package/lib/client/timeoutSettings.js +79 -0
  69. package/lib/client/tracing.js +119 -0
  70. package/lib/client/types.js +28 -0
  71. package/lib/client/video.js +59 -0
  72. package/lib/client/waiter.js +142 -0
  73. package/lib/client/webError.js +39 -0
  74. package/lib/client/webSocket.js +93 -0
  75. package/lib/client/worker.js +85 -0
  76. package/lib/client/writableStream.js +39 -0
  77. package/lib/generated/bindingsControllerSource.js +28 -0
  78. package/lib/generated/clockSource.js +28 -0
  79. package/lib/generated/injectedScriptSource.js +28 -0
  80. package/lib/generated/pollingRecorderSource.js +28 -0
  81. package/lib/generated/storageScriptSource.js +28 -0
  82. package/lib/generated/utilityScriptSource.js +28 -0
  83. package/lib/generated/webSocketMockSource.js +336 -0
  84. package/lib/inProcessFactory.js +60 -0
  85. package/lib/inprocess.js +3 -0
  86. package/lib/outofprocess.js +76 -0
  87. package/lib/protocol/serializers.js +192 -0
  88. package/lib/protocol/validator.js +2890 -0
  89. package/lib/protocol/validatorPrimitives.js +193 -0
  90. package/lib/remote/playwrightConnection.js +129 -0
  91. package/lib/remote/playwrightServer.js +335 -0
  92. package/lib/server/android/android.js +465 -0
  93. package/lib/server/android/backendAdb.js +177 -0
  94. package/lib/server/artifact.js +127 -0
  95. package/lib/server/bidi/bidiBrowser.js +505 -0
  96. package/lib/server/bidi/bidiChromium.js +153 -0
  97. package/lib/server/bidi/bidiConnection.js +212 -0
  98. package/lib/server/bidi/bidiExecutionContext.js +221 -0
  99. package/lib/server/bidi/bidiFirefox.js +130 -0
  100. package/lib/server/bidi/bidiInput.js +146 -0
  101. package/lib/server/bidi/bidiNetworkManager.js +383 -0
  102. package/lib/server/bidi/bidiOverCdp.js +102 -0
  103. package/lib/server/bidi/bidiPage.js +572 -0
  104. package/lib/server/bidi/bidiPdf.js +106 -0
  105. package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
  106. package/lib/server/bidi/third_party/bidiDeserializer.js +98 -0
  107. package/lib/server/bidi/third_party/bidiKeyboard.js +256 -0
  108. package/lib/server/bidi/third_party/bidiProtocol.js +24 -0
  109. package/lib/server/bidi/third_party/bidiProtocolCore.js +179 -0
  110. package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -0
  111. package/lib/server/bidi/third_party/bidiSerializer.js +148 -0
  112. package/lib/server/bidi/third_party/firefoxPrefs.js +259 -0
  113. package/lib/server/browser.js +149 -0
  114. package/lib/server/browserContext.js +695 -0
  115. package/lib/server/browserType.js +328 -0
  116. package/lib/server/callLog.js +82 -0
  117. package/lib/server/chromium/appIcon.png +0 -0
  118. package/lib/server/chromium/chromium.js +402 -0
  119. package/lib/server/chromium/chromiumSwitches.js +104 -0
  120. package/lib/server/chromium/crBrowser.js +510 -0
  121. package/lib/server/chromium/crConnection.js +202 -0
  122. package/lib/server/chromium/crCoverage.js +235 -0
  123. package/lib/server/chromium/crDevTools.js +113 -0
  124. package/lib/server/chromium/crDragDrop.js +131 -0
  125. package/lib/server/chromium/crExecutionContext.js +146 -0
  126. package/lib/server/chromium/crInput.js +187 -0
  127. package/lib/server/chromium/crNetworkManager.js +666 -0
  128. package/lib/server/chromium/crPage.js +1069 -0
  129. package/lib/server/chromium/crPdf.js +121 -0
  130. package/lib/server/chromium/crProtocolHelper.js +145 -0
  131. package/lib/server/chromium/crServiceWorker.js +136 -0
  132. package/lib/server/chromium/defaultFontFamilies.js +162 -0
  133. package/lib/server/chromium/protocol.d.js +16 -0
  134. package/lib/server/chromium/videoRecorder.js +115 -0
  135. package/lib/server/clock.js +149 -0
  136. package/lib/server/codegen/csharp.js +327 -0
  137. package/lib/server/codegen/java.js +274 -0
  138. package/lib/server/codegen/javascript.js +270 -0
  139. package/lib/server/codegen/jsonl.js +52 -0
  140. package/lib/server/codegen/language.js +132 -0
  141. package/lib/server/codegen/languages.js +68 -0
  142. package/lib/server/codegen/python.js +279 -0
  143. package/lib/server/codegen/types.js +16 -0
  144. package/lib/server/console.js +57 -0
  145. package/lib/server/cookieStore.js +206 -0
  146. package/lib/server/debugController.js +191 -0
  147. package/lib/server/debugger.js +119 -0
  148. package/lib/server/deviceDescriptors.js +39 -0
  149. package/lib/server/deviceDescriptorsSource.json +1779 -0
  150. package/lib/server/dialog.js +116 -0
  151. package/lib/server/dispatchers/androidDispatcher.js +325 -0
  152. package/lib/server/dispatchers/artifactDispatcher.js +118 -0
  153. package/lib/server/dispatchers/browserContextDispatcher.js +381 -0
  154. package/lib/server/dispatchers/browserDispatcher.js +118 -0
  155. package/lib/server/dispatchers/browserTypeDispatcher.js +64 -0
  156. package/lib/server/dispatchers/cdpSessionDispatcher.js +44 -0
  157. package/lib/server/dispatchers/debugControllerDispatcher.js +78 -0
  158. package/lib/server/dispatchers/dialogDispatcher.js +47 -0
  159. package/lib/server/dispatchers/dispatcher.js +371 -0
  160. package/lib/server/dispatchers/electronDispatcher.js +89 -0
  161. package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -0
  162. package/lib/server/dispatchers/frameDispatcher.js +227 -0
  163. package/lib/server/dispatchers/jsHandleDispatcher.js +85 -0
  164. package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -0
  165. package/lib/server/dispatchers/localUtilsDispatcher.js +149 -0
  166. package/lib/server/dispatchers/networkDispatchers.js +213 -0
  167. package/lib/server/dispatchers/pageDispatcher.js +389 -0
  168. package/lib/server/dispatchers/playwrightDispatcher.js +108 -0
  169. package/lib/server/dispatchers/streamDispatcher.js +67 -0
  170. package/lib/server/dispatchers/tracingDispatcher.js +68 -0
  171. package/lib/server/dispatchers/webSocketRouteDispatcher.js +165 -0
  172. package/lib/server/dispatchers/writableStreamDispatcher.js +79 -0
  173. package/lib/server/dom.js +806 -0
  174. package/lib/server/download.js +70 -0
  175. package/lib/server/electron/electron.js +270 -0
  176. package/lib/server/electron/loader.js +29 -0
  177. package/lib/server/errors.js +69 -0
  178. package/lib/server/fetch.js +621 -0
  179. package/lib/server/fileChooser.js +43 -0
  180. package/lib/server/fileUploadUtils.js +84 -0
  181. package/lib/server/firefox/ffBrowser.js +428 -0
  182. package/lib/server/firefox/ffConnection.js +147 -0
  183. package/lib/server/firefox/ffExecutionContext.js +150 -0
  184. package/lib/server/firefox/ffInput.js +159 -0
  185. package/lib/server/firefox/ffNetworkManager.js +256 -0
  186. package/lib/server/firefox/ffPage.js +500 -0
  187. package/lib/server/firefox/firefox.js +116 -0
  188. package/lib/server/firefox/protocol.d.js +16 -0
  189. package/lib/server/formData.js +147 -0
  190. package/lib/server/frameSelectors.js +154 -0
  191. package/lib/server/frames.js +1455 -0
  192. package/lib/server/har/harRecorder.js +147 -0
  193. package/lib/server/har/harTracer.js +607 -0
  194. package/lib/server/harBackend.js +157 -0
  195. package/lib/server/helper.js +96 -0
  196. package/lib/server/index.js +58 -0
  197. package/lib/server/input.js +277 -0
  198. package/lib/server/instrumentation.js +69 -0
  199. package/lib/server/javascript.js +291 -0
  200. package/lib/server/launchApp.js +128 -0
  201. package/lib/server/localUtils.js +214 -0
  202. package/lib/server/macEditingCommands.js +143 -0
  203. package/lib/server/network.js +629 -0
  204. package/lib/server/page.js +886 -0
  205. package/lib/server/pipeTransport.js +89 -0
  206. package/lib/server/playwright.js +69 -0
  207. package/lib/server/progress.js +112 -0
  208. package/lib/server/protocolError.js +52 -0
  209. package/lib/server/recorder/chat.js +161 -0
  210. package/lib/server/recorder/recorderApp.js +387 -0
  211. package/lib/server/recorder/recorderRunner.js +138 -0
  212. package/lib/server/recorder/recorderSignalProcessor.js +83 -0
  213. package/lib/server/recorder/recorderUtils.js +157 -0
  214. package/lib/server/recorder/throttledFile.js +57 -0
  215. package/lib/server/recorder.js +499 -0
  216. package/lib/server/registry/browserFetcher.js +175 -0
  217. package/lib/server/registry/dependencies.js +371 -0
  218. package/lib/server/registry/index.js +1399 -0
  219. package/lib/server/registry/nativeDeps.js +1280 -0
  220. package/lib/server/registry/oopDownloadBrowserMain.js +124 -0
  221. package/lib/server/screenshotter.js +333 -0
  222. package/lib/server/selectors.js +112 -0
  223. package/lib/server/socksClientCertificatesInterceptor.js +383 -0
  224. package/lib/server/socksInterceptor.js +95 -0
  225. package/lib/server/trace/recorder/snapshotter.js +147 -0
  226. package/lib/server/trace/recorder/snapshotterInjected.js +541 -0
  227. package/lib/server/trace/recorder/tracing.js +604 -0
  228. package/lib/server/trace/test/inMemorySnapshotter.js +87 -0
  229. package/lib/server/trace/viewer/traceViewer.js +241 -0
  230. package/lib/server/transport.js +181 -0
  231. package/lib/server/types.js +28 -0
  232. package/lib/server/usKeyboardLayout.js +145 -0
  233. package/lib/server/utils/ascii.js +44 -0
  234. package/lib/server/utils/comparators.js +139 -0
  235. package/lib/server/utils/crypto.js +216 -0
  236. package/lib/server/utils/debug.js +42 -0
  237. package/lib/server/utils/debugLogger.js +122 -0
  238. package/lib/server/utils/env.js +73 -0
  239. package/lib/server/utils/eventsHelper.js +39 -0
  240. package/lib/server/utils/expectUtils.js +38 -0
  241. package/lib/server/utils/fileUtils.js +191 -0
  242. package/lib/server/utils/happyEyeballs.js +207 -0
  243. package/lib/server/utils/hostPlatform.js +123 -0
  244. package/lib/server/utils/httpServer.js +218 -0
  245. package/lib/server/utils/imageUtils.js +141 -0
  246. package/lib/server/utils/image_tools/colorUtils.js +89 -0
  247. package/lib/server/utils/image_tools/compare.js +109 -0
  248. package/lib/server/utils/image_tools/imageChannel.js +78 -0
  249. package/lib/server/utils/image_tools/stats.js +102 -0
  250. package/lib/server/utils/linuxUtils.js +71 -0
  251. package/lib/server/utils/network.js +233 -0
  252. package/lib/server/utils/nodePlatform.js +148 -0
  253. package/lib/server/utils/pipeTransport.js +84 -0
  254. package/lib/server/utils/processLauncher.js +241 -0
  255. package/lib/server/utils/profiler.js +65 -0
  256. package/lib/server/utils/socksProxy.js +511 -0
  257. package/lib/server/utils/spawnAsync.js +41 -0
  258. package/lib/server/utils/task.js +51 -0
  259. package/lib/server/utils/userAgent.js +98 -0
  260. package/lib/server/utils/wsServer.js +121 -0
  261. package/lib/server/utils/zipFile.js +74 -0
  262. package/lib/server/utils/zones.js +57 -0
  263. package/lib/server/webkit/protocol.d.js +16 -0
  264. package/lib/server/webkit/webkit.js +110 -0
  265. package/lib/server/webkit/wkBrowser.js +339 -0
  266. package/lib/server/webkit/wkConnection.js +149 -0
  267. package/lib/server/webkit/wkExecutionContext.js +154 -0
  268. package/lib/server/webkit/wkInput.js +181 -0
  269. package/lib/server/webkit/wkInterceptableRequest.js +169 -0
  270. package/lib/server/webkit/wkPage.js +1130 -0
  271. package/lib/server/webkit/wkProvisionalPage.js +83 -0
  272. package/lib/server/webkit/wkWorkers.js +105 -0
  273. package/lib/third_party/pixelmatch.js +255 -0
  274. package/lib/utils/isomorphic/ariaSnapshot.js +397 -0
  275. package/lib/utils/isomorphic/assert.js +31 -0
  276. package/lib/utils/isomorphic/colors.js +72 -0
  277. package/lib/utils/isomorphic/cssParser.js +245 -0
  278. package/lib/utils/isomorphic/cssTokenizer.js +1051 -0
  279. package/lib/utils/isomorphic/headers.js +53 -0
  280. package/lib/utils/isomorphic/locatorGenerators.js +689 -0
  281. package/lib/utils/isomorphic/locatorParser.js +176 -0
  282. package/lib/utils/isomorphic/locatorUtils.js +81 -0
  283. package/lib/utils/isomorphic/manualPromise.js +114 -0
  284. package/lib/utils/isomorphic/mimeType.js +459 -0
  285. package/lib/utils/isomorphic/multimap.js +80 -0
  286. package/lib/utils/isomorphic/protocolFormatter.js +81 -0
  287. package/lib/utils/isomorphic/protocolMetainfo.js +322 -0
  288. package/lib/utils/isomorphic/rtti.js +43 -0
  289. package/lib/utils/isomorphic/selectorParser.js +386 -0
  290. package/lib/utils/isomorphic/semaphore.js +54 -0
  291. package/lib/utils/isomorphic/stackTrace.js +158 -0
  292. package/lib/utils/isomorphic/stringUtils.js +155 -0
  293. package/lib/utils/isomorphic/time.js +49 -0
  294. package/lib/utils/isomorphic/timeoutRunner.js +66 -0
  295. package/lib/utils/isomorphic/traceUtils.js +58 -0
  296. package/lib/utils/isomorphic/types.js +16 -0
  297. package/lib/utils/isomorphic/urlMatch.js +190 -0
  298. package/lib/utils/isomorphic/utilityScriptSerializers.js +251 -0
  299. package/lib/utils.js +109 -0
  300. package/lib/utilsBundle.js +112 -0
  301. package/lib/utilsBundleImpl/index.js +218 -0
  302. package/lib/utilsBundleImpl/xdg-open +1066 -0
  303. package/lib/vite/htmlReport/index.html +84 -0
  304. package/lib/vite/recorder/assets/codeMirrorModule-BoWUGj0J.js +25 -0
  305. package/lib/vite/recorder/assets/codeMirrorModule-C3UTv-Ge.css +1 -0
  306. package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  307. package/lib/vite/recorder/assets/index-DJqDAOZp.js +193 -0
  308. package/lib/vite/recorder/assets/index-Ri0uHF7I.css +1 -0
  309. package/lib/vite/recorder/index.html +29 -0
  310. package/lib/vite/recorder/playwright-logo.svg +9 -0
  311. package/lib/vite/traceViewer/assets/codeMirrorModule-Bucv2d7q.js +25 -0
  312. package/lib/vite/traceViewer/assets/defaultSettingsView-BEpdCv1S.js +266 -0
  313. package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
  314. package/lib/vite/traceViewer/codeMirrorModule.C3UTv-Ge.css +1 -0
  315. package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  316. package/lib/vite/traceViewer/defaultSettingsView.ConWv5KN.css +1 -0
  317. package/lib/vite/traceViewer/index.BxQ34UMZ.js +2 -0
  318. package/lib/vite/traceViewer/index.C4Y3Aw8n.css +1 -0
  319. package/lib/vite/traceViewer/index.html +43 -0
  320. package/lib/vite/traceViewer/manifest.webmanifest +16 -0
  321. package/lib/vite/traceViewer/playwright-logo.svg +9 -0
  322. package/lib/vite/traceViewer/snapshot.html +21 -0
  323. package/lib/vite/traceViewer/sw.bundle.js +3 -0
  324. package/lib/vite/traceViewer/uiMode.BWTwXl41.js +5 -0
  325. package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
  326. package/lib/vite/traceViewer/uiMode.html +17 -0
  327. package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -0
  328. package/lib/zipBundle.js +34 -0
  329. package/lib/zipBundleImpl.js +5 -0
  330. package/package.json +42 -0
  331. package/types/protocol.d.ts +23245 -0
  332. package/types/structs.d.ts +45 -0
  333. package/types/types.d.ts +22856 -0
@@ -0,0 +1,499 @@
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 recorder_exports = {};
30
+ __export(recorder_exports, {
31
+ Recorder: () => Recorder,
32
+ RecorderEvent: () => RecorderEvent
33
+ });
34
+ module.exports = __toCommonJS(recorder_exports);
35
+ var import_events = __toESM(require("events"));
36
+ var import_fs = __toESM(require("fs"));
37
+ var import_utils = require("../utils");
38
+ var import_browserContext = require("./browserContext");
39
+ var import_debugger = require("./debugger");
40
+ var import_recorderUtils = require("./recorder/recorderUtils");
41
+ var import_locatorParser = require("../utils/isomorphic/locatorParser");
42
+ var import_selectorParser = require("../utils/isomorphic/selectorParser");
43
+ var import_progress = require("./progress");
44
+ var import_recorderSignalProcessor = require("./recorder/recorderSignalProcessor");
45
+ var rawRecorderSource = __toESM(require("./../generated/pollingRecorderSource"));
46
+ var import_utils2 = require("./../utils");
47
+ var import_frames = require("./frames");
48
+ var import_page = require("./page");
49
+ var import_recorderRunner = require("./recorder/recorderRunner");
50
+ const recorderSymbol = Symbol("recorderSymbol");
51
+ const RecorderEvent = {
52
+ PausedStateChanged: "pausedStateChanged",
53
+ ModeChanged: "modeChanged",
54
+ ElementPicked: "elementPicked",
55
+ CallLogsUpdated: "callLogsUpdated",
56
+ UserSourcesChanged: "userSourcesChanged",
57
+ ActionAdded: "actionAdded",
58
+ SignalAdded: "signalAdded",
59
+ PageNavigated: "pageNavigated",
60
+ ContextClosed: "contextClosed"
61
+ };
62
+ class Recorder extends import_events.default {
63
+ constructor(context, params) {
64
+ super();
65
+ this._highlightedElement = {};
66
+ this._overlayState = { offsetX: 0 };
67
+ this._currentCallsMetadata = /* @__PURE__ */ new Map();
68
+ this._userSources = /* @__PURE__ */ new Map();
69
+ this._omitCallTracking = false;
70
+ this._currentLanguage = "javascript";
71
+ this._pageAliases = /* @__PURE__ */ new Map();
72
+ this._lastPopupOrdinal = 0;
73
+ this._lastDialogOrdinal = -1;
74
+ this._lastDownloadOrdinal = -1;
75
+ this._listeners = [];
76
+ this._enabled = false;
77
+ this._callLogs = [];
78
+ this._context = context;
79
+ this._params = params;
80
+ this._mode = params.mode || "none";
81
+ this._recorderMode = params.recorderMode ?? "default";
82
+ this.handleSIGINT = params.handleSIGINT;
83
+ this._signalProcessor = new import_recorderSignalProcessor.RecorderSignalProcessor({
84
+ addAction: (actionInContext) => {
85
+ if (this._enabled)
86
+ this.emit(RecorderEvent.ActionAdded, actionInContext);
87
+ },
88
+ addSignal: (signal) => {
89
+ if (this._enabled)
90
+ this.emit(RecorderEvent.SignalAdded, signal);
91
+ }
92
+ });
93
+ context.on(import_browserContext.BrowserContext.Events.BeforeClose, () => {
94
+ this.emit(RecorderEvent.ContextClosed);
95
+ });
96
+ this._listeners.push(import_utils2.eventsHelper.addEventListener(process, "exit", () => {
97
+ this.emit(RecorderEvent.ContextClosed);
98
+ }));
99
+ this._setEnabled(params.mode === "recording");
100
+ this._omitCallTracking = !!params.omitCallTracking;
101
+ this._debugger = context.debugger();
102
+ context.instrumentation.addListener(this, context);
103
+ if ((0, import_utils.isUnderTest)()) {
104
+ this._overlayState.offsetX = 200;
105
+ }
106
+ }
107
+ static forContext(context, params) {
108
+ let recorderPromise = context[recorderSymbol];
109
+ if (!recorderPromise) {
110
+ recorderPromise = Recorder._create(context, params);
111
+ context[recorderSymbol] = recorderPromise;
112
+ }
113
+ return recorderPromise;
114
+ }
115
+ static async existingForContext(context) {
116
+ const recorderPromise = context[recorderSymbol];
117
+ return await recorderPromise;
118
+ }
119
+ static async _create(context, params = {}) {
120
+ const recorder = new Recorder(context, params);
121
+ await recorder._install();
122
+ return recorder;
123
+ }
124
+ async _install() {
125
+ this.emit(RecorderEvent.ModeChanged, this._mode);
126
+ this.emit(RecorderEvent.PausedStateChanged, this._debugger.isPaused());
127
+ this._context.once(import_browserContext.BrowserContext.Events.Close, () => {
128
+ import_utils2.eventsHelper.removeEventListeners(this._listeners);
129
+ this._context.instrumentation.removeListener(this);
130
+ this.emit(RecorderEvent.ContextClosed);
131
+ });
132
+ const controller = new import_progress.ProgressController();
133
+ await controller.run(async (progress) => {
134
+ await this._context.exposeBinding(progress, "__pw_recorderState", false, async (source) => {
135
+ let actionSelector;
136
+ let actionPoint;
137
+ const hasActiveScreenshotCommand = [...this._currentCallsMetadata.keys()].some(isScreenshotCommand);
138
+ if (!hasActiveScreenshotCommand) {
139
+ actionSelector = await this._scopeHighlightedSelectorToFrame(source.frame);
140
+ for (const [metadata, sdkObject] of this._currentCallsMetadata) {
141
+ if (source.page === sdkObject.attribution.page) {
142
+ actionPoint = metadata.point || actionPoint;
143
+ actionSelector = actionSelector || metadata.params.selector;
144
+ }
145
+ }
146
+ }
147
+ const uiState = {
148
+ mode: this._mode,
149
+ actionPoint,
150
+ actionSelector,
151
+ ariaTemplate: this._highlightedElement.ariaTemplate,
152
+ language: this._currentLanguage,
153
+ testIdAttributeName: this._testIdAttributeName(),
154
+ overlay: this._overlayState
155
+ };
156
+ return uiState;
157
+ });
158
+ await this._context.exposeBinding(progress, "__pw_recorderElementPicked", false, async ({ frame }, elementInfo) => {
159
+ const selectorChain = await (0, import_recorderUtils.generateFrameSelector)(frame);
160
+ this.emit(RecorderEvent.ElementPicked, { selector: (0, import_recorderUtils.buildFullSelector)(selectorChain, elementInfo.selector), ariaSnapshot: elementInfo.ariaSnapshot }, true);
161
+ });
162
+ await this._context.exposeBinding(progress, "__pw_recorderSetMode", false, async ({ frame }, mode) => {
163
+ if (frame.parentFrame())
164
+ return;
165
+ this.setMode(mode);
166
+ });
167
+ await this._context.exposeBinding(progress, "__pw_recorderSetOverlayState", false, async ({ frame }, state) => {
168
+ if (frame.parentFrame())
169
+ return;
170
+ this._overlayState = state;
171
+ });
172
+ await this._context.exposeBinding(progress, "__pw_resume", false, () => {
173
+ this._debugger.resume(false);
174
+ });
175
+ this._context.on(import_browserContext.BrowserContext.Events.Page, (page) => this._onPage(page));
176
+ for (const page of this._context.pages())
177
+ this._onPage(page);
178
+ this._context.dialogManager.addDialogHandler((dialog) => {
179
+ this._onDialog(dialog.page());
180
+ return false;
181
+ });
182
+ await this._context.exposeBinding(
183
+ progress,
184
+ "__pw_recorderPerformAction",
185
+ false,
186
+ (source, action) => this._performAction(source.frame, action)
187
+ );
188
+ await this._context.exposeBinding(
189
+ progress,
190
+ "__pw_recorderRecordAction",
191
+ false,
192
+ (source, action) => this._recordAction(source.frame, action)
193
+ );
194
+ await this._context.extendInjectedScript(rawRecorderSource.source, { recorderMode: this._recorderMode });
195
+ });
196
+ if (this._debugger.isPaused())
197
+ this._pausedStateChanged();
198
+ this._debugger.on(import_debugger.Debugger.Events.PausedStateChanged, () => this._pausedStateChanged());
199
+ }
200
+ _pausedStateChanged() {
201
+ for (const { metadata, sdkObject } of this._debugger.pausedDetails()) {
202
+ if (!this._currentCallsMetadata.has(metadata))
203
+ this.onBeforeCall(sdkObject, metadata);
204
+ }
205
+ this.emit(RecorderEvent.PausedStateChanged, this._debugger.isPaused());
206
+ this._updateUserSources();
207
+ this.updateCallLog([...this._currentCallsMetadata.keys()]);
208
+ }
209
+ mode() {
210
+ return this._mode;
211
+ }
212
+ setMode(mode) {
213
+ if (this._mode === mode)
214
+ return;
215
+ this._highlightedElement = {};
216
+ this._mode = mode;
217
+ this.emit(RecorderEvent.ModeChanged, this._mode);
218
+ this._setEnabled(this._isRecording());
219
+ this._debugger.setMuted(this._isRecording());
220
+ if (this._mode !== "none" && this._mode !== "standby" && this._context.pages().length === 1)
221
+ this._context.pages()[0].bringToFront().catch(() => {
222
+ });
223
+ this._refreshOverlay();
224
+ }
225
+ url() {
226
+ const page = this._context.pages()[0];
227
+ return page?.mainFrame().url();
228
+ }
229
+ setHighlightedSelector(selector) {
230
+ this._highlightedElement = { selector: (0, import_locatorParser.locatorOrSelectorAsSelector)(this._currentLanguage, selector, this._context.selectors().testIdAttributeName()) };
231
+ this._refreshOverlay();
232
+ }
233
+ setHighlightedAriaTemplate(ariaTemplate) {
234
+ this._highlightedElement = { ariaTemplate };
235
+ this._refreshOverlay();
236
+ }
237
+ step() {
238
+ this._debugger.resume(true);
239
+ }
240
+ setLanguage(language) {
241
+ this._currentLanguage = language;
242
+ this._refreshOverlay();
243
+ }
244
+ resume() {
245
+ this._debugger.resume(false);
246
+ }
247
+ pause() {
248
+ this._debugger.pauseOnNextStatement();
249
+ }
250
+ paused() {
251
+ return this._debugger.isPaused();
252
+ }
253
+ close() {
254
+ this._debugger.resume(false);
255
+ }
256
+ hideHighlightedSelector() {
257
+ this._highlightedElement = {};
258
+ this._refreshOverlay();
259
+ }
260
+ pausedSourceId() {
261
+ for (const { metadata } of this._debugger.pausedDetails()) {
262
+ if (!metadata.location)
263
+ continue;
264
+ const source = this._userSources.get(metadata.location.file);
265
+ if (!source)
266
+ continue;
267
+ return source.id;
268
+ }
269
+ }
270
+ userSources() {
271
+ return [...this._userSources.values()];
272
+ }
273
+ callLog() {
274
+ return this._callLogs;
275
+ }
276
+ async _scopeHighlightedSelectorToFrame(frame) {
277
+ if (!this._highlightedElement.selector)
278
+ return;
279
+ try {
280
+ const mainFrame = frame._page.mainFrame();
281
+ const resolved = await mainFrame.selectors.resolveFrameForSelector(this._highlightedElement.selector);
282
+ if (!resolved)
283
+ return "";
284
+ if (resolved?.frame === mainFrame)
285
+ return (0, import_selectorParser.stringifySelector)(resolved.info.parsed);
286
+ if (resolved?.frame === frame)
287
+ return (0, import_selectorParser.stringifySelector)(resolved.info.parsed);
288
+ return "";
289
+ } catch {
290
+ return "";
291
+ }
292
+ }
293
+ _refreshOverlay() {
294
+ for (const page of this._context.pages()) {
295
+ for (const frame of page.frames())
296
+ frame.evaluateExpression("window.__pw_refreshOverlay()").catch(() => {
297
+ });
298
+ }
299
+ }
300
+ async onBeforeCall(sdkObject, metadata) {
301
+ if (this._omitCallTracking || this._isRecording())
302
+ return;
303
+ this._currentCallsMetadata.set(metadata, sdkObject);
304
+ this._updateUserSources();
305
+ this.updateCallLog([metadata]);
306
+ if (isScreenshotCommand(metadata))
307
+ this.hideHighlightedSelector();
308
+ else if (metadata.params && metadata.params.selector)
309
+ this._highlightedElement = { selector: metadata.params.selector };
310
+ }
311
+ async onAfterCall(sdkObject, metadata) {
312
+ if (this._omitCallTracking || this._isRecording())
313
+ return;
314
+ if (!metadata.error)
315
+ this._currentCallsMetadata.delete(metadata);
316
+ this._updateUserSources();
317
+ this.updateCallLog([metadata]);
318
+ }
319
+ _updateUserSources() {
320
+ for (const source of this._userSources.values()) {
321
+ source.highlight = [];
322
+ source.revealLine = void 0;
323
+ }
324
+ for (const metadata of this._currentCallsMetadata.keys()) {
325
+ if (!metadata.location)
326
+ continue;
327
+ const { file, line } = metadata.location;
328
+ let source = this._userSources.get(file);
329
+ if (!source) {
330
+ source = { isRecorded: false, label: file, id: file, text: this._readSource(file), highlight: [], language: languageForFile(file) };
331
+ this._userSources.set(file, source);
332
+ }
333
+ if (line) {
334
+ const paused = this._debugger.isPaused(metadata);
335
+ source.highlight.push({ line, type: metadata.error ? "error" : paused ? "paused" : "running" });
336
+ source.revealLine = line;
337
+ }
338
+ }
339
+ this.emit(RecorderEvent.UserSourcesChanged, this.userSources(), this.pausedSourceId());
340
+ }
341
+ async onBeforeInputAction(sdkObject, metadata) {
342
+ }
343
+ async onCallLog(sdkObject, metadata, logName, message) {
344
+ this.updateCallLog([metadata]);
345
+ }
346
+ updateCallLog(metadatas) {
347
+ if (this._isRecording())
348
+ return;
349
+ const logs = [];
350
+ for (const metadata of metadatas) {
351
+ if (!metadata.method || metadata.internal)
352
+ continue;
353
+ let status = "done";
354
+ if (this._currentCallsMetadata.has(metadata))
355
+ status = "in-progress";
356
+ if (this._debugger.isPaused(metadata))
357
+ status = "paused";
358
+ logs.push((0, import_recorderUtils.metadataToCallLog)(metadata, status));
359
+ }
360
+ this._callLogs = logs;
361
+ this.emit(RecorderEvent.CallLogsUpdated, logs);
362
+ }
363
+ _isRecording() {
364
+ return ["recording", "assertingText", "assertingVisibility", "assertingValue", "assertingSnapshot"].includes(this._mode);
365
+ }
366
+ _readSource(fileName) {
367
+ try {
368
+ return import_fs.default.readFileSync(fileName, "utf-8");
369
+ } catch (e) {
370
+ return "// No source available";
371
+ }
372
+ }
373
+ _setEnabled(enabled) {
374
+ this._enabled = enabled;
375
+ }
376
+ async _onPage(page) {
377
+ const frame = page.mainFrame();
378
+ page.on(import_page.Page.Events.Close, () => {
379
+ this._signalProcessor.addAction({
380
+ frame: this._describeMainFrame(page),
381
+ action: {
382
+ name: "closePage",
383
+ signals: []
384
+ },
385
+ startTime: (0, import_utils2.monotonicTime)()
386
+ });
387
+ this._pageAliases.delete(page);
388
+ this._filePrimaryURLChanged();
389
+ });
390
+ frame.on(import_frames.Frame.Events.InternalNavigation, (event) => {
391
+ if (event.isPublic) {
392
+ this._onFrameNavigated(frame, page);
393
+ this._filePrimaryURLChanged();
394
+ }
395
+ });
396
+ page.on(import_page.Page.Events.Download, () => this._onDownload(page));
397
+ const suffix = this._pageAliases.size ? String(++this._lastPopupOrdinal) : "";
398
+ const pageAlias = "page" + suffix;
399
+ this._pageAliases.set(page, pageAlias);
400
+ if (page.opener()) {
401
+ this._onPopup(page.opener(), page);
402
+ } else {
403
+ this._signalProcessor.addAction({
404
+ frame: this._describeMainFrame(page),
405
+ action: {
406
+ name: "openPage",
407
+ url: page.mainFrame().url(),
408
+ signals: []
409
+ },
410
+ startTime: (0, import_utils2.monotonicTime)()
411
+ });
412
+ }
413
+ this._filePrimaryURLChanged();
414
+ }
415
+ _filePrimaryURLChanged() {
416
+ const page = this._context.pages()[0];
417
+ this.emit(RecorderEvent.PageNavigated, page?.mainFrame().url());
418
+ }
419
+ clear() {
420
+ if (this._params.mode === "recording") {
421
+ for (const page of this._context.pages())
422
+ this._onFrameNavigated(page.mainFrame(), page);
423
+ }
424
+ }
425
+ _describeMainFrame(page) {
426
+ return {
427
+ pageGuid: page.guid,
428
+ pageAlias: this._pageAliases.get(page),
429
+ framePath: []
430
+ };
431
+ }
432
+ async _describeFrame(frame) {
433
+ return {
434
+ pageGuid: frame._page.guid,
435
+ pageAlias: this._pageAliases.get(frame._page),
436
+ framePath: await (0, import_recorderUtils.generateFrameSelector)(frame)
437
+ };
438
+ }
439
+ _testIdAttributeName() {
440
+ return this._params.testIdAttributeName || this._context.selectors().testIdAttributeName() || "data-testid";
441
+ }
442
+ async _createActionInContext(frame, action) {
443
+ const frameDescription = await this._describeFrame(frame);
444
+ const actionInContext = {
445
+ frame: frameDescription,
446
+ action,
447
+ description: void 0,
448
+ startTime: (0, import_utils2.monotonicTime)()
449
+ };
450
+ return actionInContext;
451
+ }
452
+ async _performAction(frame, action) {
453
+ const actionInContext = await this._createActionInContext(frame, action);
454
+ this._signalProcessor.addAction(actionInContext);
455
+ if (actionInContext.action.name !== "openPage" && actionInContext.action.name !== "closePage")
456
+ await (0, import_recorderRunner.performAction)(this._pageAliases, actionInContext);
457
+ actionInContext.endTime = (0, import_utils2.monotonicTime)();
458
+ }
459
+ async _recordAction(frame, action) {
460
+ const actionInContext = await this._createActionInContext(frame, action);
461
+ this._signalProcessor.addAction(actionInContext);
462
+ }
463
+ _onFrameNavigated(frame, page) {
464
+ const pageAlias = this._pageAliases.get(page);
465
+ this._signalProcessor.signal(pageAlias, frame, { name: "navigation", url: frame.url() });
466
+ }
467
+ _onPopup(page, popup) {
468
+ const pageAlias = this._pageAliases.get(page);
469
+ const popupAlias = this._pageAliases.get(popup);
470
+ this._signalProcessor.signal(pageAlias, page.mainFrame(), { name: "popup", popupAlias });
471
+ }
472
+ _onDownload(page) {
473
+ const pageAlias = this._pageAliases.get(page);
474
+ ++this._lastDownloadOrdinal;
475
+ this._signalProcessor.signal(pageAlias, page.mainFrame(), { name: "download", downloadAlias: this._lastDownloadOrdinal ? String(this._lastDownloadOrdinal) : "" });
476
+ }
477
+ _onDialog(page) {
478
+ const pageAlias = this._pageAliases.get(page);
479
+ ++this._lastDialogOrdinal;
480
+ this._signalProcessor.signal(pageAlias, page.mainFrame(), { name: "dialog", dialogAlias: this._lastDialogOrdinal ? String(this._lastDialogOrdinal) : "" });
481
+ }
482
+ }
483
+ function isScreenshotCommand(metadata) {
484
+ return metadata.method.toLowerCase().includes("screenshot");
485
+ }
486
+ function languageForFile(file) {
487
+ if (file.endsWith(".py"))
488
+ return "python";
489
+ if (file.endsWith(".java"))
490
+ return "java";
491
+ if (file.endsWith(".cs"))
492
+ return "csharp";
493
+ return "javascript";
494
+ }
495
+ // Annotate the CommonJS export names for ESM import in node:
496
+ 0 && (module.exports = {
497
+ Recorder,
498
+ RecorderEvent
499
+ });
@@ -0,0 +1,175 @@
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 browserFetcher_exports = {};
30
+ __export(browserFetcher_exports, {
31
+ downloadBrowserWithProgressBar: () => downloadBrowserWithProgressBar,
32
+ logPolitely: () => logPolitely
33
+ });
34
+ module.exports = __toCommonJS(browserFetcher_exports);
35
+ var childProcess = __toESM(require("child_process"));
36
+ var import_fs = __toESM(require("fs"));
37
+ var import_os = __toESM(require("os"));
38
+ var import_path = __toESM(require("path"));
39
+ var import_debugLogger = require("../utils/debugLogger");
40
+ var import_manualPromise = require("../../utils/isomorphic/manualPromise");
41
+ var import_userAgent = require("../utils/userAgent");
42
+ var import_utilsBundle = require("../../utilsBundle");
43
+ var import_fileUtils = require("../utils/fileUtils");
44
+ var import__ = require(".");
45
+ async function downloadBrowserWithProgressBar(title, browserDirectory, executablePath, downloadURLs, downloadFileName, downloadSocketTimeout) {
46
+ if (await (0, import_fileUtils.existsAsync)((0, import__.browserDirectoryToMarkerFilePath)(browserDirectory))) {
47
+ import_debugLogger.debugLogger.log("install", `${title} is already downloaded.`);
48
+ return false;
49
+ }
50
+ const uniqueTempDir = await import_fs.default.promises.mkdtemp(import_path.default.join(import_os.default.tmpdir(), "playwright-download-"));
51
+ const zipPath = import_path.default.join(uniqueTempDir, downloadFileName);
52
+ try {
53
+ const retryCount = 5;
54
+ for (let attempt = 1; attempt <= retryCount; ++attempt) {
55
+ import_debugLogger.debugLogger.log("install", `downloading ${title} - attempt #${attempt}`);
56
+ const url = downloadURLs[(attempt - 1) % downloadURLs.length];
57
+ logPolitely(`Downloading ${title}` + import_utilsBundle.colors.dim(` from ${url}`));
58
+ const { error } = await downloadBrowserWithProgressBarOutOfProcess(title, browserDirectory, url, zipPath, executablePath, downloadSocketTimeout);
59
+ if (!error) {
60
+ import_debugLogger.debugLogger.log("install", `SUCCESS installing ${title}`);
61
+ break;
62
+ }
63
+ if (await (0, import_fileUtils.existsAsync)(zipPath))
64
+ await import_fs.default.promises.unlink(zipPath);
65
+ if (await (0, import_fileUtils.existsAsync)(browserDirectory))
66
+ await import_fs.default.promises.rmdir(browserDirectory, { recursive: true });
67
+ const errorMessage = error?.message || "";
68
+ import_debugLogger.debugLogger.log("install", `attempt #${attempt} - ERROR: ${errorMessage}`);
69
+ if (attempt >= retryCount)
70
+ throw error;
71
+ }
72
+ } catch (e) {
73
+ import_debugLogger.debugLogger.log("install", `FAILED installation ${title} with error: ${e}`);
74
+ process.exitCode = 1;
75
+ throw e;
76
+ } finally {
77
+ await (0, import_fileUtils.removeFolders)([uniqueTempDir]);
78
+ }
79
+ logPolitely(`${title} downloaded to ${browserDirectory}`);
80
+ return true;
81
+ }
82
+ function downloadBrowserWithProgressBarOutOfProcess(title, browserDirectory, url, zipPath, executablePath, socketTimeout) {
83
+ const cp = childProcess.fork(import_path.default.join(__dirname, "oopDownloadBrowserMain.js"));
84
+ const promise = new import_manualPromise.ManualPromise();
85
+ const progress = getDownloadProgress();
86
+ cp.on("message", (message) => {
87
+ if (message?.method === "log")
88
+ import_debugLogger.debugLogger.log("install", message.params.message);
89
+ if (message?.method === "progress")
90
+ progress(message.params.done, message.params.total);
91
+ });
92
+ cp.on("exit", (code) => {
93
+ if (code !== 0) {
94
+ promise.resolve({ error: new Error(`Download failure, code=${code}`) });
95
+ return;
96
+ }
97
+ if (!import_fs.default.existsSync((0, import__.browserDirectoryToMarkerFilePath)(browserDirectory)))
98
+ promise.resolve({ error: new Error(`Download failure, ${(0, import__.browserDirectoryToMarkerFilePath)(browserDirectory)} does not exist`) });
99
+ else
100
+ promise.resolve({ error: null });
101
+ });
102
+ cp.on("error", (error) => {
103
+ promise.resolve({ error });
104
+ });
105
+ import_debugLogger.debugLogger.log("install", `running download:`);
106
+ import_debugLogger.debugLogger.log("install", `-- from url: ${url}`);
107
+ import_debugLogger.debugLogger.log("install", `-- to location: ${zipPath}`);
108
+ const downloadParams = {
109
+ title,
110
+ browserDirectory,
111
+ url,
112
+ zipPath,
113
+ executablePath,
114
+ socketTimeout,
115
+ userAgent: (0, import_userAgent.getUserAgent)()
116
+ };
117
+ cp.send({ method: "download", params: downloadParams });
118
+ return promise;
119
+ }
120
+ function logPolitely(toBeLogged) {
121
+ const logLevel = process.env.npm_config_loglevel;
122
+ const logLevelDisplay = ["silent", "error", "warn"].indexOf(logLevel || "") > -1;
123
+ if (!logLevelDisplay)
124
+ console.log(toBeLogged);
125
+ }
126
+ function getDownloadProgress() {
127
+ if (process.stdout.isTTY)
128
+ return getAnimatedDownloadProgress();
129
+ return getBasicDownloadProgress();
130
+ }
131
+ function getAnimatedDownloadProgress() {
132
+ let progressBar;
133
+ let lastDownloadedBytes = 0;
134
+ return (downloadedBytes, totalBytes) => {
135
+ if (!progressBar) {
136
+ progressBar = new import_utilsBundle.progress(
137
+ `${toMegabytes(
138
+ totalBytes
139
+ )} [:bar] :percent :etas`,
140
+ {
141
+ complete: "=",
142
+ incomplete: " ",
143
+ width: 20,
144
+ total: totalBytes
145
+ }
146
+ );
147
+ }
148
+ const delta = downloadedBytes - lastDownloadedBytes;
149
+ lastDownloadedBytes = downloadedBytes;
150
+ progressBar.tick(delta);
151
+ };
152
+ }
153
+ function getBasicDownloadProgress() {
154
+ const totalRows = 10;
155
+ const stepWidth = 8;
156
+ let lastRow = -1;
157
+ return (downloadedBytes, totalBytes) => {
158
+ const percentage = downloadedBytes / totalBytes;
159
+ const row = Math.floor(totalRows * percentage);
160
+ if (row > lastRow) {
161
+ lastRow = row;
162
+ const percentageString = String(percentage * 100 | 0).padStart(3);
163
+ console.log(`|${"\u25A0".repeat(row * stepWidth)}${" ".repeat((totalRows - row) * stepWidth)}| ${percentageString}% of ${toMegabytes(totalBytes)}`);
164
+ }
165
+ };
166
+ }
167
+ function toMegabytes(bytes) {
168
+ const mb = bytes / 1024 / 1024;
169
+ return `${Math.round(mb * 10) / 10} MiB`;
170
+ }
171
+ // Annotate the CommonJS export names for ESM import in node:
172
+ 0 && (module.exports = {
173
+ downloadBrowserWithProgressBar,
174
+ logPolitely
175
+ });