patchright-core 1.48.2

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 +1548 -0
  3. package/bin/PrintDeps.exe +0 -0
  4. package/bin/README.md +2 -0
  5. package/bin/install_media_pack.ps1 +5 -0
  6. package/bin/reinstall_chrome_beta_linux.sh +40 -0
  7. package/bin/reinstall_chrome_beta_mac.sh +13 -0
  8. package/bin/reinstall_chrome_beta_win.ps1 +24 -0
  9. package/bin/reinstall_chrome_stable_linux.sh +40 -0
  10. package/bin/reinstall_chrome_stable_mac.sh +12 -0
  11. package/bin/reinstall_chrome_stable_win.ps1 +24 -0
  12. package/bin/reinstall_msedge_beta_linux.sh +40 -0
  13. package/bin/reinstall_msedge_beta_mac.sh +11 -0
  14. package/bin/reinstall_msedge_beta_win.ps1 +23 -0
  15. package/bin/reinstall_msedge_dev_linux.sh +40 -0
  16. package/bin/reinstall_msedge_dev_mac.sh +11 -0
  17. package/bin/reinstall_msedge_dev_win.ps1 +23 -0
  18. package/bin/reinstall_msedge_stable_linux.sh +40 -0
  19. package/bin/reinstall_msedge_stable_mac.sh +11 -0
  20. package/bin/reinstall_msedge_stable_win.ps1 +24 -0
  21. package/browsers.json +57 -0
  22. package/cli.js +18 -0
  23. package/index.d.ts +17 -0
  24. package/index.js +33 -0
  25. package/index.mjs +28 -0
  26. package/lib/androidServerImpl.js +69 -0
  27. package/lib/browserServerImpl.js +92 -0
  28. package/lib/cli/driver.js +95 -0
  29. package/lib/cli/program.js +589 -0
  30. package/lib/cli/programWithTestStub.js +67 -0
  31. package/lib/client/accessibility.js +50 -0
  32. package/lib/client/android.js +473 -0
  33. package/lib/client/api.js +285 -0
  34. package/lib/client/artifact.js +79 -0
  35. package/lib/client/browser.js +145 -0
  36. package/lib/client/browserContext.js +583 -0
  37. package/lib/client/browserType.js +241 -0
  38. package/lib/client/cdpSession.js +53 -0
  39. package/lib/client/channelOwner.js +235 -0
  40. package/lib/client/clientHelper.js +57 -0
  41. package/lib/client/clientInstrumentation.js +50 -0
  42. package/lib/client/clock.js +69 -0
  43. package/lib/client/connection.js +333 -0
  44. package/lib/client/consoleMessage.js +55 -0
  45. package/lib/client/coverage.js +41 -0
  46. package/lib/client/dialog.js +57 -0
  47. package/lib/client/download.js +62 -0
  48. package/lib/client/electron.js +135 -0
  49. package/lib/client/elementHandle.js +321 -0
  50. package/lib/client/errors.js +77 -0
  51. package/lib/client/eventEmitter.js +314 -0
  52. package/lib/client/events.js +94 -0
  53. package/lib/client/fetch.js +391 -0
  54. package/lib/client/fileChooser.js +45 -0
  55. package/lib/client/frame.js +504 -0
  56. package/lib/client/harRouter.js +99 -0
  57. package/lib/client/input.js +111 -0
  58. package/lib/client/jsHandle.js +121 -0
  59. package/lib/client/jsonPipe.js +35 -0
  60. package/lib/client/localUtils.js +36 -0
  61. package/lib/client/locator.js +441 -0
  62. package/lib/client/network.js +762 -0
  63. package/lib/client/page.js +770 -0
  64. package/lib/client/playwright.js +80 -0
  65. package/lib/client/selectors.js +67 -0
  66. package/lib/client/stream.js +54 -0
  67. package/lib/client/tracing.js +134 -0
  68. package/lib/client/types.js +24 -0
  69. package/lib/client/video.js +51 -0
  70. package/lib/client/waiter.js +158 -0
  71. package/lib/client/webError.js +37 -0
  72. package/lib/client/worker.js +71 -0
  73. package/lib/client/writableStream.js +54 -0
  74. package/lib/common/socksProxy.js +569 -0
  75. package/lib/common/timeoutSettings.js +73 -0
  76. package/lib/common/types.js +5 -0
  77. package/lib/generated/clockSource.js +7 -0
  78. package/lib/generated/consoleApiSource.js +7 -0
  79. package/lib/generated/injectedScriptSource.js +7 -0
  80. package/lib/generated/pollingRecorderSource.js +7 -0
  81. package/lib/generated/utilityScriptSource.js +7 -0
  82. package/lib/generated/webSocketMockSource.js +7 -0
  83. package/lib/image_tools/colorUtils.js +98 -0
  84. package/lib/image_tools/compare.js +108 -0
  85. package/lib/image_tools/imageChannel.js +70 -0
  86. package/lib/image_tools/stats.js +102 -0
  87. package/lib/inProcessFactory.js +54 -0
  88. package/lib/inprocess.js +20 -0
  89. package/lib/outofprocess.js +67 -0
  90. package/lib/protocol/debug.js +27 -0
  91. package/lib/protocol/serializers.js +173 -0
  92. package/lib/protocol/transport.js +82 -0
  93. package/lib/protocol/validator.js +2760 -0
  94. package/lib/protocol/validatorPrimitives.js +139 -0
  95. package/lib/remote/playwrightConnection.js +274 -0
  96. package/lib/remote/playwrightServer.js +110 -0
  97. package/lib/server/accessibility.js +62 -0
  98. package/lib/server/android/android.js +441 -0
  99. package/lib/server/android/backendAdb.js +172 -0
  100. package/lib/server/artifact.js +104 -0
  101. package/lib/server/bidi/bidiBrowser.js +311 -0
  102. package/lib/server/bidi/bidiChromium.js +124 -0
  103. package/lib/server/bidi/bidiConnection.js +206 -0
  104. package/lib/server/bidi/bidiExecutionContext.js +159 -0
  105. package/lib/server/bidi/bidiFirefox.js +104 -0
  106. package/lib/server/bidi/bidiInput.js +158 -0
  107. package/lib/server/bidi/bidiNetworkManager.js +338 -0
  108. package/lib/server/bidi/bidiOverCdp.js +103 -0
  109. package/lib/server/bidi/bidiPage.js +529 -0
  110. package/lib/server/bidi/bidiPdf.js +140 -0
  111. package/lib/server/bidi/third_party/bidiDeserializer.js +93 -0
  112. package/lib/server/bidi/third_party/bidiKeyboard.js +238 -0
  113. package/lib/server/bidi/third_party/bidiProtocol.js +139 -0
  114. package/lib/server/bidi/third_party/bidiSerializer.js +144 -0
  115. package/lib/server/bidi/third_party/firefoxPrefs.js +221 -0
  116. package/lib/server/browser.js +148 -0
  117. package/lib/server/browserContext.js +666 -0
  118. package/lib/server/browserType.js +335 -0
  119. package/lib/server/chromium/appIcon.png +0 -0
  120. package/lib/server/chromium/chromium.js +350 -0
  121. package/lib/server/chromium/chromiumSwitches.js +36 -0
  122. package/lib/server/chromium/crAccessibility.js +237 -0
  123. package/lib/server/chromium/crBrowser.js +522 -0
  124. package/lib/server/chromium/crConnection.js +228 -0
  125. package/lib/server/chromium/crCoverage.js +246 -0
  126. package/lib/server/chromium/crDevTools.js +104 -0
  127. package/lib/server/chromium/crDragDrop.js +143 -0
  128. package/lib/server/chromium/crExecutionContext.js +149 -0
  129. package/lib/server/chromium/crInput.js +171 -0
  130. package/lib/server/chromium/crNetworkManager.js +809 -0
  131. package/lib/server/chromium/crPage.js +1235 -0
  132. package/lib/server/chromium/crPdf.js +153 -0
  133. package/lib/server/chromium/crProtocolHelper.js +133 -0
  134. package/lib/server/chromium/crServiceWorker.js +111 -0
  135. package/lib/server/chromium/defaultFontFamilies.js +145 -0
  136. package/lib/server/chromium/videoRecorder.js +155 -0
  137. package/lib/server/clock.js +133 -0
  138. package/lib/server/codegen/csharp.js +299 -0
  139. package/lib/server/codegen/java.js +235 -0
  140. package/lib/server/codegen/javascript.js +223 -0
  141. package/lib/server/codegen/jsonl.js +47 -0
  142. package/lib/server/codegen/language.js +88 -0
  143. package/lib/server/codegen/languages.js +30 -0
  144. package/lib/server/codegen/python.js +265 -0
  145. package/lib/server/codegen/types.js +5 -0
  146. package/lib/server/console.js +57 -0
  147. package/lib/server/cookieStore.js +185 -0
  148. package/lib/server/debugController.js +234 -0
  149. package/lib/server/debugger.js +132 -0
  150. package/lib/server/deviceDescriptors.js +26 -0
  151. package/lib/server/deviceDescriptorsSource.json +1669 -0
  152. package/lib/server/dialog.js +71 -0
  153. package/lib/server/dispatchers/androidDispatcher.js +193 -0
  154. package/lib/server/dispatchers/artifactDispatcher.js +118 -0
  155. package/lib/server/dispatchers/browserContextDispatcher.js +368 -0
  156. package/lib/server/dispatchers/browserDispatcher.js +170 -0
  157. package/lib/server/dispatchers/browserTypeDispatcher.js +55 -0
  158. package/lib/server/dispatchers/cdpSessionDispatcher.js +48 -0
  159. package/lib/server/dispatchers/debugControllerDispatcher.js +103 -0
  160. package/lib/server/dispatchers/dialogDispatcher.js +44 -0
  161. package/lib/server/dispatchers/dispatcher.js +395 -0
  162. package/lib/server/dispatchers/electronDispatcher.js +93 -0
  163. package/lib/server/dispatchers/elementHandlerDispatcher.js +228 -0
  164. package/lib/server/dispatchers/frameDispatcher.js +286 -0
  165. package/lib/server/dispatchers/jsHandleDispatcher.js +97 -0
  166. package/lib/server/dispatchers/jsonPipeDispatcher.js +59 -0
  167. package/lib/server/dispatchers/localUtilsDispatcher.js +413 -0
  168. package/lib/server/dispatchers/networkDispatchers.js +221 -0
  169. package/lib/server/dispatchers/pageDispatcher.js +367 -0
  170. package/lib/server/dispatchers/playwrightDispatcher.js +107 -0
  171. package/lib/server/dispatchers/selectorsDispatcher.js +36 -0
  172. package/lib/server/dispatchers/streamDispatcher.js +62 -0
  173. package/lib/server/dispatchers/tracingDispatcher.js +54 -0
  174. package/lib/server/dispatchers/webSocketRouteDispatcher.js +189 -0
  175. package/lib/server/dispatchers/writableStreamDispatcher.js +58 -0
  176. package/lib/server/dom.js +845 -0
  177. package/lib/server/download.js +60 -0
  178. package/lib/server/electron/electron.js +296 -0
  179. package/lib/server/electron/loader.js +57 -0
  180. package/lib/server/errors.js +68 -0
  181. package/lib/server/fetch.js +656 -0
  182. package/lib/server/fileChooser.js +42 -0
  183. package/lib/server/fileUploadUtils.js +75 -0
  184. package/lib/server/firefox/ffAccessibility.js +216 -0
  185. package/lib/server/firefox/ffBrowser.js +460 -0
  186. package/lib/server/firefox/ffConnection.js +168 -0
  187. package/lib/server/firefox/ffExecutionContext.js +135 -0
  188. package/lib/server/firefox/ffInput.js +150 -0
  189. package/lib/server/firefox/ffNetworkManager.js +233 -0
  190. package/lib/server/firefox/ffPage.js +559 -0
  191. package/lib/server/firefox/firefox.js +99 -0
  192. package/lib/server/formData.js +75 -0
  193. package/lib/server/frameSelectors.js +171 -0
  194. package/lib/server/frames.js +1808 -0
  195. package/lib/server/har/harRecorder.js +139 -0
  196. package/lib/server/har/harTracer.js +542 -0
  197. package/lib/server/helper.js +103 -0
  198. package/lib/server/index.js +114 -0
  199. package/lib/server/input.js +310 -0
  200. package/lib/server/instrumentation.js +70 -0
  201. package/lib/server/isomorphic/utilityScriptSerializers.js +226 -0
  202. package/lib/server/javascript.js +299 -0
  203. package/lib/server/launchApp.js +91 -0
  204. package/lib/server/macEditingCommands.js +139 -0
  205. package/lib/server/network.js +617 -0
  206. package/lib/server/page.js +819 -0
  207. package/lib/server/pipeTransport.js +85 -0
  208. package/lib/server/playwright.js +88 -0
  209. package/lib/server/progress.js +102 -0
  210. package/lib/server/protocolError.js +49 -0
  211. package/lib/server/recorder/contextRecorder.js +299 -0
  212. package/lib/server/recorder/recorderApp.js +196 -0
  213. package/lib/server/recorder/recorderCollection.js +116 -0
  214. package/lib/server/recorder/recorderFrontend.js +5 -0
  215. package/lib/server/recorder/recorderInTraceViewer.js +144 -0
  216. package/lib/server/recorder/recorderRunner.js +155 -0
  217. package/lib/server/recorder/recorderUtils.js +112 -0
  218. package/lib/server/recorder/throttledFile.js +46 -0
  219. package/lib/server/recorder.js +329 -0
  220. package/lib/server/registry/browserFetcher.js +168 -0
  221. package/lib/server/registry/dependencies.js +322 -0
  222. package/lib/server/registry/index.js +1005 -0
  223. package/lib/server/registry/nativeDeps.js +490 -0
  224. package/lib/server/registry/oopDownloadBrowserMain.js +138 -0
  225. package/lib/server/screenshotter.js +348 -0
  226. package/lib/server/selectors.js +73 -0
  227. package/lib/server/socksClientCertificatesInterceptor.js +340 -0
  228. package/lib/server/socksInterceptor.js +100 -0
  229. package/lib/server/trace/recorder/snapshotter.js +172 -0
  230. package/lib/server/trace/recorder/snapshotterInjected.js +493 -0
  231. package/lib/server/trace/recorder/tracing.js +542 -0
  232. package/lib/server/trace/test/inMemorySnapshotter.js +93 -0
  233. package/lib/server/trace/viewer/traceViewer.js +213 -0
  234. package/lib/server/transport.js +191 -0
  235. package/lib/server/types.js +24 -0
  236. package/lib/server/usKeyboardLayout.js +555 -0
  237. package/lib/server/webkit/webkit.js +87 -0
  238. package/lib/server/webkit/wkAccessibility.js +194 -0
  239. package/lib/server/webkit/wkBrowser.js +329 -0
  240. package/lib/server/webkit/wkConnection.js +173 -0
  241. package/lib/server/webkit/wkExecutionContext.js +143 -0
  242. package/lib/server/webkit/wkInput.js +169 -0
  243. package/lib/server/webkit/wkInterceptableRequest.js +162 -0
  244. package/lib/server/webkit/wkPage.js +1219 -0
  245. package/lib/server/webkit/wkProvisionalPage.js +94 -0
  246. package/lib/server/webkit/wkWorkers.js +104 -0
  247. package/lib/third_party/diff_match_patch.js +2222 -0
  248. package/lib/third_party/pixelmatch.js +255 -0
  249. package/lib/utils/ascii.js +31 -0
  250. package/lib/utils/comparators.js +171 -0
  251. package/lib/utils/crypto.js +174 -0
  252. package/lib/utils/debug.js +46 -0
  253. package/lib/utils/debugLogger.js +91 -0
  254. package/lib/utils/env.js +49 -0
  255. package/lib/utils/eventsHelper.js +38 -0
  256. package/lib/utils/expectUtils.js +33 -0
  257. package/lib/utils/fileUtils.js +205 -0
  258. package/lib/utils/happy-eyeballs.js +194 -0
  259. package/lib/utils/headers.js +52 -0
  260. package/lib/utils/hostPlatform.js +133 -0
  261. package/lib/utils/httpServer.js +237 -0
  262. package/lib/utils/index.js +368 -0
  263. package/lib/utils/isomorphic/cssParser.js +250 -0
  264. package/lib/utils/isomorphic/cssTokenizer.js +979 -0
  265. package/lib/utils/isomorphic/locatorGenerators.js +642 -0
  266. package/lib/utils/isomorphic/locatorParser.js +179 -0
  267. package/lib/utils/isomorphic/locatorUtils.js +62 -0
  268. package/lib/utils/isomorphic/mimeType.js +29 -0
  269. package/lib/utils/isomorphic/recorderUtils.js +195 -0
  270. package/lib/utils/isomorphic/selectorParser.js +397 -0
  271. package/lib/utils/isomorphic/stringUtils.js +139 -0
  272. package/lib/utils/isomorphic/traceUtils.js +39 -0
  273. package/lib/utils/isomorphic/urlMatch.js +120 -0
  274. package/lib/utils/linuxUtils.js +78 -0
  275. package/lib/utils/manualPromise.js +109 -0
  276. package/lib/utils/multimap.js +75 -0
  277. package/lib/utils/network.js +160 -0
  278. package/lib/utils/processLauncher.js +248 -0
  279. package/lib/utils/profiler.js +53 -0
  280. package/lib/utils/rtti.js +44 -0
  281. package/lib/utils/semaphore.js +51 -0
  282. package/lib/utils/spawnAsync.js +45 -0
  283. package/lib/utils/stackTrace.js +121 -0
  284. package/lib/utils/task.js +58 -0
  285. package/lib/utils/time.js +37 -0
  286. package/lib/utils/timeoutRunner.js +66 -0
  287. package/lib/utils/traceUtils.js +44 -0
  288. package/lib/utils/userAgent.js +105 -0
  289. package/lib/utils/wsServer.js +127 -0
  290. package/lib/utils/zipFile.js +75 -0
  291. package/lib/utils/zones.js +62 -0
  292. package/lib/utilsBundle.js +82 -0
  293. package/lib/utilsBundleImpl/index.js +53 -0
  294. package/lib/utilsBundleImpl/xdg-open +1066 -0
  295. package/lib/vite/htmlReport/index.html +66 -0
  296. package/lib/vite/recorder/assets/codeMirrorModule-baozm8ur.js +24 -0
  297. package/lib/vite/recorder/assets/codeMirrorModule-ez37Vkbh.css +1 -0
  298. package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  299. package/lib/vite/recorder/assets/index-2ElAIWFB.js +42 -0
  300. package/lib/vite/recorder/assets/index-BW-aOBcL.css +1 -0
  301. package/lib/vite/recorder/index.html +29 -0
  302. package/lib/vite/recorder/playwright-logo.svg +9 -0
  303. package/lib/vite/traceViewer/assets/codeMirrorModule-Bh1rfd2w.js +24 -0
  304. package/lib/vite/traceViewer/assets/inspectorTab-7GHnKvSD.js +64 -0
  305. package/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +1 -0
  306. package/lib/vite/traceViewer/assets/workbench-DPQnTHYP.js +9 -0
  307. package/lib/vite/traceViewer/assets/xtermModule-BeNbaIVa.js +9 -0
  308. package/lib/vite/traceViewer/codeMirrorModule.ez37Vkbh.css +1 -0
  309. package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  310. package/lib/vite/traceViewer/embedded.BlHoW5LY.js +2 -0
  311. package/lib/vite/traceViewer/embedded.html +18 -0
  312. package/lib/vite/traceViewer/embedded.w7WN2u1R.css +1 -0
  313. package/lib/vite/traceViewer/index.CrbWWHbf.css +1 -0
  314. package/lib/vite/traceViewer/index.DaWVfou1.js +2 -0
  315. package/lib/vite/traceViewer/index.html +29 -0
  316. package/lib/vite/traceViewer/inspectorTab.DLjBDrQR.css +1 -0
  317. package/lib/vite/traceViewer/playwright-logo.svg +9 -0
  318. package/lib/vite/traceViewer/recorder.B_SY1GJM.css +0 -0
  319. package/lib/vite/traceViewer/recorder.C4zxcvd2.js +2 -0
  320. package/lib/vite/traceViewer/recorder.html +17 -0
  321. package/lib/vite/traceViewer/snapshot.html +21 -0
  322. package/lib/vite/traceViewer/sw.bundle.js +3 -0
  323. package/lib/vite/traceViewer/uiMode.CAYqod-m.css +1 -0
  324. package/lib/vite/traceViewer/uiMode.html +20 -0
  325. package/lib/vite/traceViewer/uiMode.mTXWniJb.js +5 -0
  326. package/lib/vite/traceViewer/workbench.D3JVcA9K.css +1 -0
  327. package/lib/vite/traceViewer/xtermModule.DSXBckUd.css +32 -0
  328. package/lib/zipBundle.js +25 -0
  329. package/lib/zipBundleImpl.js +5 -0
  330. package/package.json +44 -0
  331. package/types/protocol.d.ts +21571 -0
  332. package/types/structs.d.ts +45 -0
  333. package/types/types.d.ts +22519 -0
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.callMetadataForAction = callMetadataForAction;
7
+ exports.collapseActions = collapseActions;
8
+ exports.frameForAction = frameForAction;
9
+ exports.mainFrameForAction = mainFrameForAction;
10
+ exports.metadataToCallLog = metadataToCallLog;
11
+ var _utils = require("../../utils");
12
+ var _recorderUtils = require("../../utils/isomorphic/recorderUtils");
13
+ /**
14
+ * Copyright (c) Microsoft Corporation.
15
+ *
16
+ * Licensed under the Apache License, Version 2.0 (the "License");
17
+ * you may not use this file except in compliance with the License.
18
+ * You may obtain a copy of the License at
19
+ *
20
+ * http://www.apache.org/licenses/LICENSE-2.0
21
+ *
22
+ * Unless required by applicable law or agreed to in writing, software
23
+ * distributed under the License is distributed on an "AS IS" BASIS,
24
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
25
+ * See the License for the specific language governing permissions and
26
+ * limitations under the License.
27
+ */
28
+
29
+ function metadataToCallLog(metadata, status) {
30
+ var _metadata$params, _metadata$params2, _metadata$error;
31
+ let title = metadata.apiName || metadata.method;
32
+ if (metadata.method === 'waitForEventInfo') title += `(${metadata.params.info.event})`;
33
+ title = title.replace('object.expect', 'expect');
34
+ if (metadata.error) status = 'error';
35
+ const params = {
36
+ url: (_metadata$params = metadata.params) === null || _metadata$params === void 0 ? void 0 : _metadata$params.url,
37
+ selector: (_metadata$params2 = metadata.params) === null || _metadata$params2 === void 0 ? void 0 : _metadata$params2.selector
38
+ };
39
+ let duration = metadata.endTime ? metadata.endTime - metadata.startTime : undefined;
40
+ if (typeof duration === 'number' && metadata.pauseStartTime && metadata.pauseEndTime) {
41
+ duration -= metadata.pauseEndTime - metadata.pauseStartTime;
42
+ duration = Math.max(duration, 0);
43
+ }
44
+ const callLog = {
45
+ id: metadata.id,
46
+ messages: metadata.log,
47
+ title,
48
+ status,
49
+ error: (_metadata$error = metadata.error) === null || _metadata$error === void 0 || (_metadata$error = _metadata$error.error) === null || _metadata$error === void 0 ? void 0 : _metadata$error.message,
50
+ params,
51
+ duration
52
+ };
53
+ return callLog;
54
+ }
55
+ function mainFrameForAction(pageAliases, actionInContext) {
56
+ var _find;
57
+ const pageAlias = actionInContext.frame.pageAlias;
58
+ const page = (_find = [...pageAliases.entries()].find(([, alias]) => pageAlias === alias)) === null || _find === void 0 ? void 0 : _find[0];
59
+ if (!page) throw new Error(`Internal error: page ${pageAlias} not found in [${[...pageAliases.values()]}]`);
60
+ return page.mainFrame();
61
+ }
62
+ async function frameForAction(pageAliases, actionInContext, action) {
63
+ var _find2;
64
+ const pageAlias = actionInContext.frame.pageAlias;
65
+ const page = (_find2 = [...pageAliases.entries()].find(([, alias]) => pageAlias === alias)) === null || _find2 === void 0 ? void 0 : _find2[0];
66
+ if (!page) throw new Error('Internal error: page not found');
67
+ const fullSelector = (0, _recorderUtils.buildFullSelector)(actionInContext.frame.framePath, action.selector);
68
+ const result = await page.mainFrame().selectors.resolveFrameForSelector(fullSelector);
69
+ if (!result) throw new Error('Internal error: frame not found');
70
+ return result.frame;
71
+ }
72
+ function callMetadataForAction(pageAliases, actionInContext) {
73
+ const mainFrame = mainFrameForAction(pageAliases, actionInContext);
74
+ const {
75
+ method,
76
+ params
77
+ } = (0, _recorderUtils.traceParamsForAction)(actionInContext);
78
+ const callMetadata = {
79
+ id: `call@${(0, _utils.createGuid)()}`,
80
+ apiName: 'page.' + method,
81
+ objectId: mainFrame.guid,
82
+ pageId: mainFrame._page.guid,
83
+ frameId: mainFrame.guid,
84
+ startTime: actionInContext.startTime,
85
+ endTime: 0,
86
+ type: 'Frame',
87
+ method,
88
+ params,
89
+ log: []
90
+ };
91
+ return {
92
+ callMetadata,
93
+ mainFrame
94
+ };
95
+ }
96
+ function collapseActions(actions) {
97
+ const result = [];
98
+ for (const action of actions) {
99
+ const lastAction = result[result.length - 1];
100
+ const isSameAction = lastAction && lastAction.action.name === action.action.name && lastAction.frame.pageAlias === action.frame.pageAlias && lastAction.frame.framePath.join('|') === action.frame.framePath.join('|');
101
+ const isSameSelector = lastAction && 'selector' in lastAction.action && 'selector' in action.action && action.action.selector === lastAction.action.selector;
102
+ const shouldMerge = isSameAction && (action.action.name === 'navigate' || action.action.name === 'fill' && isSameSelector);
103
+ if (!shouldMerge) {
104
+ result.push(action);
105
+ continue;
106
+ }
107
+ const startTime = result[result.length - 1].startTime;
108
+ result[result.length - 1] = action;
109
+ result[result.length - 1].startTime = startTime;
110
+ }
111
+ return result;
112
+ }
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ThrottledFile = void 0;
7
+ var fs = _interopRequireWildcard(require("fs"));
8
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
9
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
10
+ /**
11
+ * Copyright (c) Microsoft Corporation.
12
+ *
13
+ * Licensed under the Apache License, Version 2.0 (the "License");
14
+ * you may not use this file except in compliance with the License.
15
+ * You may obtain a copy of the License at
16
+ *
17
+ * http://www.apache.org/licenses/LICENSE-2.0
18
+ *
19
+ * Unless required by applicable law or agreed to in writing, software
20
+ * distributed under the License is distributed on an "AS IS" BASIS,
21
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
22
+ * See the License for the specific language governing permissions and
23
+ * limitations under the License.
24
+ */
25
+
26
+ class ThrottledFile {
27
+ constructor(file) {
28
+ this._file = void 0;
29
+ this._timer = void 0;
30
+ this._text = void 0;
31
+ this._file = file;
32
+ }
33
+ setContent(text) {
34
+ this._text = text;
35
+ if (!this._timer) this._timer = setTimeout(() => this.flush(), 250);
36
+ }
37
+ flush() {
38
+ if (this._timer) {
39
+ clearTimeout(this._timer);
40
+ this._timer = undefined;
41
+ }
42
+ if (this._text) fs.writeFileSync(this._file, this._text);
43
+ this._text = undefined;
44
+ }
45
+ }
46
+ exports.ThrottledFile = ThrottledFile;
@@ -0,0 +1,329 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Recorder = void 0;
7
+ var fs = _interopRequireWildcard(require("fs"));
8
+ var consoleApiSource = _interopRequireWildcard(require("../generated/consoleApiSource"));
9
+ var _utils = require("../utils");
10
+ var _locatorParser = require("../utils/isomorphic/locatorParser");
11
+ var _browserContext = require("./browserContext");
12
+ var _debugger = require("./debugger");
13
+ var _contextRecorder = require("./recorder/contextRecorder");
14
+ var _recorderUtils = require("./recorder/recorderUtils");
15
+ var _recorderUtils2 = require("../utils/isomorphic/recorderUtils");
16
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
17
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
18
+ /**
19
+ * Copyright (c) Microsoft Corporation.
20
+ *
21
+ * Licensed under the Apache License, Version 2.0 (the "License");
22
+ * you may not use this file except in compliance with the License.
23
+ * You may obtain a copy of the License at
24
+ *
25
+ * http://www.apache.org/licenses/LICENSE-2.0
26
+ *
27
+ * Unless required by applicable law or agreed to in writing, software
28
+ * distributed under the License is distributed on an "AS IS" BASIS,
29
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
30
+ * See the License for the specific language governing permissions and
31
+ * limitations under the License.
32
+ */
33
+
34
+ const recorderSymbol = Symbol('recorderSymbol');
35
+ class Recorder {
36
+ static async showInspector(context, params, recorderAppFactory) {
37
+ if ((0, _utils.isUnderTest)()) params.language = process.env.TEST_INSPECTOR_LANGUAGE;
38
+ return await Recorder.show('actions', context, recorderAppFactory, params);
39
+ }
40
+ static showInspectorNoReply(context, recorderAppFactory) {
41
+ Recorder.showInspector(context, {}, recorderAppFactory).catch(() => {});
42
+ }
43
+ static show(codegenMode, context, recorderAppFactory, params) {
44
+ let recorderPromise = context[recorderSymbol];
45
+ if (!recorderPromise) {
46
+ recorderPromise = Recorder._create(codegenMode, context, recorderAppFactory, params);
47
+ context[recorderSymbol] = recorderPromise;
48
+ }
49
+ return recorderPromise;
50
+ }
51
+ static async _create(codegenMode, context, recorderAppFactory, params = {}) {
52
+ const recorder = new Recorder(codegenMode, context, params);
53
+ const recorderApp = await recorderAppFactory(recorder);
54
+ await recorder._install(recorderApp);
55
+ return recorder;
56
+ }
57
+ constructor(codegenMode, context, params) {
58
+ this.handleSIGINT = void 0;
59
+ this._context = void 0;
60
+ this._mode = void 0;
61
+ this._highlightedSelector = '';
62
+ this._overlayState = {
63
+ offsetX: 0
64
+ };
65
+ this._recorderApp = null;
66
+ this._currentCallsMetadata = new Map();
67
+ this._recorderSources = [];
68
+ this._userSources = new Map();
69
+ this._debugger = void 0;
70
+ this._contextRecorder = void 0;
71
+ this._omitCallTracking = false;
72
+ this._currentLanguage = void 0;
73
+ this._mode = params.mode || 'none';
74
+ this.handleSIGINT = params.handleSIGINT;
75
+ this._contextRecorder = new _contextRecorder.ContextRecorder(codegenMode, context, params, {});
76
+ this._context = context;
77
+ this._omitCallTracking = !!params.omitCallTracking;
78
+ this._debugger = context.debugger();
79
+ context.instrumentation.addListener(this, context);
80
+ this._currentLanguage = this._contextRecorder.languageName();
81
+ if ((0, _utils.isUnderTest)()) {
82
+ // Most of our tests put elements at the top left, so get out of the way.
83
+ this._overlayState.offsetX = 200;
84
+ }
85
+ }
86
+ async _install(recorderApp) {
87
+ this._recorderApp = recorderApp;
88
+ recorderApp.once('close', () => {
89
+ this._debugger.resume(false);
90
+ this._recorderApp = null;
91
+ });
92
+ recorderApp.on('event', data => {
93
+ if (data.event === 'setMode') {
94
+ this.setMode(data.params.mode);
95
+ return;
96
+ }
97
+ if (data.event === 'selectorUpdated') {
98
+ this.setHighlightedSelector(this._currentLanguage, data.params.selector);
99
+ return;
100
+ }
101
+ if (data.event === 'step') {
102
+ this._debugger.resume(true);
103
+ return;
104
+ }
105
+ if (data.event === 'fileChanged') {
106
+ this._currentLanguage = this._contextRecorder.languageName(data.params.file);
107
+ this._refreshOverlay();
108
+ return;
109
+ }
110
+ if (data.event === 'resume') {
111
+ this._debugger.resume(false);
112
+ return;
113
+ }
114
+ if (data.event === 'pause') {
115
+ this._debugger.pauseOnNextStatement();
116
+ return;
117
+ }
118
+ if (data.event === 'clear') {
119
+ this._contextRecorder.clearScript();
120
+ return;
121
+ }
122
+ });
123
+ await Promise.all([recorderApp.setMode(this._mode), recorderApp.setPaused(this._debugger.isPaused()), this._pushAllSources()]);
124
+ this._context.once(_browserContext.BrowserContext.Events.Close, () => {
125
+ var _this$_recorderApp;
126
+ this._contextRecorder.dispose();
127
+ this._context.instrumentation.removeListener(this);
128
+ (_this$_recorderApp = this._recorderApp) === null || _this$_recorderApp === void 0 || _this$_recorderApp.close().catch(() => {});
129
+ });
130
+ this._contextRecorder.on(_contextRecorder.ContextRecorder.Events.Change, data => {
131
+ this._recorderSources = data.sources;
132
+ recorderApp.setActions(data.actions, data.sources);
133
+ recorderApp.setRunningFile(undefined);
134
+ this._pushAllSources();
135
+ });
136
+ await this._context.exposeBinding('__pw_recorderState', false, source => {
137
+ let actionSelector = '';
138
+ let actionPoint;
139
+ const hasActiveScreenshotCommand = [...this._currentCallsMetadata.keys()].some(isScreenshotCommand);
140
+ if (!hasActiveScreenshotCommand) {
141
+ actionSelector = this._highlightedSelector;
142
+ for (const [metadata, sdkObject] of this._currentCallsMetadata) {
143
+ if (source.page === sdkObject.attribution.page) {
144
+ actionPoint = metadata.point || actionPoint;
145
+ actionSelector = actionSelector || metadata.params.selector;
146
+ }
147
+ }
148
+ }
149
+ const uiState = {
150
+ mode: this._mode,
151
+ actionPoint,
152
+ actionSelector,
153
+ language: this._currentLanguage,
154
+ testIdAttributeName: this._contextRecorder.testIdAttributeName(),
155
+ overlay: this._overlayState
156
+ };
157
+ return uiState;
158
+ });
159
+ await this._context.exposeBinding('__pw_recorderSetSelector', false, async ({
160
+ frame
161
+ }, selector) => {
162
+ var _this$_recorderApp2;
163
+ const selectorChain = await (0, _contextRecorder.generateFrameSelector)(frame);
164
+ await ((_this$_recorderApp2 = this._recorderApp) === null || _this$_recorderApp2 === void 0 ? void 0 : _this$_recorderApp2.setSelector((0, _recorderUtils2.buildFullSelector)(selectorChain, selector), true));
165
+ });
166
+ await this._context.exposeBinding('__pw_recorderSetMode', false, async ({
167
+ frame
168
+ }, mode) => {
169
+ if (frame.parentFrame()) return;
170
+ this.setMode(mode);
171
+ });
172
+ await this._context.exposeBinding('__pw_recorderSetOverlayState', false, async ({
173
+ frame
174
+ }, state) => {
175
+ if (frame.parentFrame()) return;
176
+ this._overlayState = state;
177
+ });
178
+ await this._context.exposeBinding('__pw_resume', false, () => {
179
+ this._debugger.resume(false);
180
+ });
181
+ await this._context.extendInjectedScript(consoleApiSource.source);
182
+ await this._contextRecorder.install();
183
+ if (this._debugger.isPaused()) this._pausedStateChanged();
184
+ this._debugger.on(_debugger.Debugger.Events.PausedStateChanged, () => this._pausedStateChanged());
185
+ this._context.recorderAppForTest = this._recorderApp;
186
+ }
187
+ _pausedStateChanged() {
188
+ var _this$_recorderApp3;
189
+ // If we are called upon page.pause, we don't have metadatas, populate them.
190
+ for (const {
191
+ metadata,
192
+ sdkObject
193
+ } of this._debugger.pausedDetails()) {
194
+ if (!this._currentCallsMetadata.has(metadata)) this.onBeforeCall(sdkObject, metadata);
195
+ }
196
+ (_this$_recorderApp3 = this._recorderApp) === null || _this$_recorderApp3 === void 0 || _this$_recorderApp3.setPaused(this._debugger.isPaused());
197
+ this._updateUserSources();
198
+ this.updateCallLog([...this._currentCallsMetadata.keys()]);
199
+ }
200
+ setMode(mode) {
201
+ var _this$_recorderApp4;
202
+ if (this._mode === mode) return;
203
+ this._highlightedSelector = '';
204
+ this._mode = mode;
205
+ (_this$_recorderApp4 = this._recorderApp) === null || _this$_recorderApp4 === void 0 || _this$_recorderApp4.setMode(this._mode);
206
+ this._contextRecorder.setEnabled(this._mode === 'recording' || this._mode === 'assertingText' || this._mode === 'assertingVisibility' || this._mode === 'assertingValue');
207
+ this._debugger.setMuted(this._mode === 'recording' || this._mode === 'assertingText' || this._mode === 'assertingVisibility' || this._mode === 'assertingValue');
208
+ if (this._mode !== 'none' && this._mode !== 'standby' && this._context.pages().length === 1) this._context.pages()[0].bringToFront().catch(() => {});
209
+ this._refreshOverlay();
210
+ }
211
+ resume() {
212
+ this._debugger.resume(false);
213
+ }
214
+ mode() {
215
+ return this._mode;
216
+ }
217
+ setHighlightedSelector(language, selector) {
218
+ this._highlightedSelector = (0, _locatorParser.locatorOrSelectorAsSelector)(language, selector, this._context.selectors().testIdAttributeName());
219
+ this._refreshOverlay();
220
+ }
221
+ hideHighlightedSelector() {
222
+ this._highlightedSelector = '';
223
+ this._refreshOverlay();
224
+ }
225
+ setOutput(codegenId, outputFile) {
226
+ this._contextRecorder.setOutput(codegenId, outputFile);
227
+ }
228
+ _refreshOverlay() {
229
+ for (const page of this._context.pages()) page.mainFrame().evaluateExpression('window.__pw_refreshOverlay()').catch(() => {});
230
+ }
231
+ async onBeforeCall(sdkObject, metadata) {
232
+ if (this._omitCallTracking || this._mode === 'recording' || this._mode === 'assertingText' || this._mode === 'assertingVisibility' || this._mode === 'assertingValue') return;
233
+ this._currentCallsMetadata.set(metadata, sdkObject);
234
+ this._updateUserSources();
235
+ this.updateCallLog([metadata]);
236
+ if (isScreenshotCommand(metadata)) {
237
+ this.hideHighlightedSelector();
238
+ } else if (metadata.params && metadata.params.selector) {
239
+ var _this$_recorderApp5;
240
+ this._highlightedSelector = metadata.params.selector;
241
+ (_this$_recorderApp5 = this._recorderApp) === null || _this$_recorderApp5 === void 0 || _this$_recorderApp5.setSelector(this._highlightedSelector).catch(() => {});
242
+ }
243
+ }
244
+ async onAfterCall(sdkObject, metadata) {
245
+ if (this._omitCallTracking || this._mode === 'recording' || this._mode === 'assertingText' || this._mode === 'assertingVisibility' || this._mode === 'assertingValue') return;
246
+ if (!metadata.error) this._currentCallsMetadata.delete(metadata);
247
+ this._updateUserSources();
248
+ this.updateCallLog([metadata]);
249
+ }
250
+ _updateUserSources() {
251
+ var _this$_recorderApp6;
252
+ // Remove old decorations.
253
+ for (const source of this._userSources.values()) {
254
+ source.highlight = [];
255
+ source.revealLine = undefined;
256
+ }
257
+
258
+ // Apply new decorations.
259
+ let fileToSelect = undefined;
260
+ for (const metadata of this._currentCallsMetadata.keys()) {
261
+ if (!metadata.location) continue;
262
+ const {
263
+ file,
264
+ line
265
+ } = metadata.location;
266
+ let source = this._userSources.get(file);
267
+ if (!source) {
268
+ source = {
269
+ isRecorded: false,
270
+ label: file,
271
+ id: file,
272
+ text: this._readSource(file),
273
+ highlight: [],
274
+ language: languageForFile(file)
275
+ };
276
+ this._userSources.set(file, source);
277
+ }
278
+ if (line) {
279
+ const paused = this._debugger.isPaused(metadata);
280
+ source.highlight.push({
281
+ line,
282
+ type: metadata.error ? 'error' : paused ? 'paused' : 'running'
283
+ });
284
+ source.revealLine = line;
285
+ fileToSelect = source.id;
286
+ }
287
+ }
288
+ this._pushAllSources();
289
+ if (fileToSelect) (_this$_recorderApp6 = this._recorderApp) === null || _this$_recorderApp6 === void 0 || _this$_recorderApp6.setRunningFile(fileToSelect);
290
+ }
291
+ _pushAllSources() {
292
+ var _this$_recorderApp7;
293
+ (_this$_recorderApp7 = this._recorderApp) === null || _this$_recorderApp7 === void 0 || _this$_recorderApp7.setSources([...this._recorderSources, ...this._userSources.values()]);
294
+ }
295
+ async onBeforeInputAction(sdkObject, metadata) {}
296
+ async onCallLog(sdkObject, metadata, logName, message) {
297
+ this.updateCallLog([metadata]);
298
+ }
299
+ updateCallLog(metadatas) {
300
+ var _this$_recorderApp8;
301
+ if (this._mode === 'recording' || this._mode === 'assertingText' || this._mode === 'assertingVisibility' || this._mode === 'assertingValue') return;
302
+ const logs = [];
303
+ for (const metadata of metadatas) {
304
+ if (!metadata.method || metadata.internal) continue;
305
+ let status = 'done';
306
+ if (this._currentCallsMetadata.has(metadata)) status = 'in-progress';
307
+ if (this._debugger.isPaused(metadata)) status = 'paused';
308
+ logs.push((0, _recorderUtils.metadataToCallLog)(metadata, status));
309
+ }
310
+ (_this$_recorderApp8 = this._recorderApp) === null || _this$_recorderApp8 === void 0 || _this$_recorderApp8.updateCallLogs(logs);
311
+ }
312
+ _readSource(fileName) {
313
+ try {
314
+ return fs.readFileSync(fileName, 'utf-8');
315
+ } catch (e) {
316
+ return '// No source available';
317
+ }
318
+ }
319
+ }
320
+ exports.Recorder = Recorder;
321
+ function isScreenshotCommand(metadata) {
322
+ return metadata.method.toLowerCase().includes('screenshot');
323
+ }
324
+ function languageForFile(file) {
325
+ if (file.endsWith('.py')) return 'python';
326
+ if (file.endsWith('.java')) return 'java';
327
+ if (file.endsWith('.cs')) return 'csharp';
328
+ return 'javascript';
329
+ }
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.downloadBrowserWithProgressBar = downloadBrowserWithProgressBar;
7
+ exports.logPolitely = logPolitely;
8
+ var _fs = _interopRequireDefault(require("fs"));
9
+ var _os = _interopRequireDefault(require("os"));
10
+ var _path = _interopRequireDefault(require("path"));
11
+ var _child_process = _interopRequireDefault(require("child_process"));
12
+ var _fileUtils = require("../../utils/fileUtils");
13
+ var _debugLogger = require("../../utils/debugLogger");
14
+ var _manualPromise = require("../../utils/manualPromise");
15
+ var _utilsBundle = require("../../utilsBundle");
16
+ var _ = require(".");
17
+ var _userAgent = require("../../utils/userAgent");
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+ /**
20
+ * Copyright 2017 Google Inc. All rights reserved.
21
+ * Modifications copyright (c) Microsoft Corporation.
22
+ *
23
+ * Licensed under the Apache License, Version 2.0 (the "License");
24
+ * you may not use this file except in compliance with the License.
25
+ * You may obtain a copy of the License at
26
+ *
27
+ * http://www.apache.org/licenses/LICENSE-2.0
28
+ *
29
+ * Unless required by applicable law or agreed to in writing, software
30
+ * distributed under the License is distributed on an "AS IS" BASIS,
31
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
32
+ * See the License for the specific language governing permissions and
33
+ * limitations under the License.
34
+ */
35
+
36
+ async function downloadBrowserWithProgressBar(title, browserDirectory, executablePath, downloadURLs, downloadFileName, downloadConnectionTimeout) {
37
+ if (await (0, _fileUtils.existsAsync)((0, _.browserDirectoryToMarkerFilePath)(browserDirectory))) {
38
+ // Already downloaded.
39
+ _debugLogger.debugLogger.log('install', `${title} is already downloaded.`);
40
+ return false;
41
+ }
42
+ const zipPath = _path.default.join(_os.default.tmpdir(), downloadFileName);
43
+ try {
44
+ const retryCount = 3;
45
+ for (let attempt = 1; attempt <= retryCount; ++attempt) {
46
+ _debugLogger.debugLogger.log('install', `downloading ${title} - attempt #${attempt}`);
47
+ const url = downloadURLs[(attempt - 1) % downloadURLs.length];
48
+ logPolitely(`Downloading ${title}` + _utilsBundle.colors.dim(` from ${url}`));
49
+ const {
50
+ error
51
+ } = await downloadBrowserWithProgressBarOutOfProcess(title, browserDirectory, url, zipPath, executablePath, downloadConnectionTimeout);
52
+ if (!error) {
53
+ _debugLogger.debugLogger.log('install', `SUCCESS installing ${title}`);
54
+ break;
55
+ }
56
+ if (await (0, _fileUtils.existsAsync)(zipPath)) await _fs.default.promises.unlink(zipPath);
57
+ if (await (0, _fileUtils.existsAsync)(browserDirectory)) await _fs.default.promises.rmdir(browserDirectory, {
58
+ recursive: true
59
+ });
60
+ const errorMessage = (error === null || error === void 0 ? void 0 : error.message) || '';
61
+ _debugLogger.debugLogger.log('install', `attempt #${attempt} - ERROR: ${errorMessage}`);
62
+ if (attempt >= retryCount) throw error;
63
+ }
64
+ } catch (e) {
65
+ _debugLogger.debugLogger.log('install', `FAILED installation ${title} with error: ${e}`);
66
+ process.exitCode = 1;
67
+ throw e;
68
+ } finally {
69
+ if (await (0, _fileUtils.existsAsync)(zipPath)) await _fs.default.promises.unlink(zipPath);
70
+ }
71
+ logPolitely(`${title} downloaded to ${browserDirectory}`);
72
+ return true;
73
+ }
74
+
75
+ /**
76
+ * Node.js has a bug where the process can exit with 0 code even though there was an uncaught exception.
77
+ * Thats why we execute it in a separate process and check manually if the destination file exists.
78
+ * https://github.com/microsoft/playwright/issues/17394
79
+ */
80
+ function downloadBrowserWithProgressBarOutOfProcess(title, browserDirectory, url, zipPath, executablePath, connectionTimeout) {
81
+ const cp = _child_process.default.fork(_path.default.join(__dirname, 'oopDownloadBrowserMain.js'));
82
+ const promise = new _manualPromise.ManualPromise();
83
+ const progress = getDownloadProgress();
84
+ cp.on('message', message => {
85
+ if ((message === null || message === void 0 ? void 0 : message.method) === 'log') _debugLogger.debugLogger.log('install', message.params.message);
86
+ if ((message === null || message === void 0 ? void 0 : message.method) === 'progress') progress(message.params.done, message.params.total);
87
+ });
88
+ cp.on('exit', code => {
89
+ if (code !== 0) {
90
+ promise.resolve({
91
+ error: new Error(`Download failure, code=${code}`)
92
+ });
93
+ return;
94
+ }
95
+ if (!_fs.default.existsSync((0, _.browserDirectoryToMarkerFilePath)(browserDirectory))) promise.resolve({
96
+ error: new Error(`Download failure, ${(0, _.browserDirectoryToMarkerFilePath)(browserDirectory)} does not exist`)
97
+ });else promise.resolve({
98
+ error: null
99
+ });
100
+ });
101
+ cp.on('error', error => {
102
+ promise.resolve({
103
+ error
104
+ });
105
+ });
106
+ _debugLogger.debugLogger.log('install', `running download:`);
107
+ _debugLogger.debugLogger.log('install', `-- from url: ${url}`);
108
+ _debugLogger.debugLogger.log('install', `-- to location: ${zipPath}`);
109
+ const downloadParams = {
110
+ title,
111
+ browserDirectory,
112
+ url,
113
+ zipPath,
114
+ executablePath,
115
+ connectionTimeout,
116
+ userAgent: (0, _userAgent.getUserAgent)()
117
+ };
118
+ cp.send({
119
+ method: 'download',
120
+ params: downloadParams
121
+ });
122
+ return promise;
123
+ }
124
+ function logPolitely(toBeLogged) {
125
+ const logLevel = process.env.npm_config_loglevel;
126
+ const logLevelDisplay = ['silent', 'error', 'warn'].indexOf(logLevel || '') > -1;
127
+ if (!logLevelDisplay) console.log(toBeLogged); // eslint-disable-line no-console
128
+ }
129
+ function getDownloadProgress() {
130
+ if (process.stdout.isTTY) return getAnimatedDownloadProgress();
131
+ return getBasicDownloadProgress();
132
+ }
133
+ function getAnimatedDownloadProgress() {
134
+ let progressBar;
135
+ let lastDownloadedBytes = 0;
136
+ return (downloadedBytes, totalBytes) => {
137
+ if (!progressBar) {
138
+ progressBar = new _utilsBundle.progress(`${toMegabytes(totalBytes)} [:bar] :percent :etas`, {
139
+ complete: '=',
140
+ incomplete: ' ',
141
+ width: 20,
142
+ total: totalBytes
143
+ });
144
+ }
145
+ const delta = downloadedBytes - lastDownloadedBytes;
146
+ lastDownloadedBytes = downloadedBytes;
147
+ progressBar.tick(delta);
148
+ };
149
+ }
150
+ function getBasicDownloadProgress() {
151
+ const totalRows = 10;
152
+ const stepWidth = 8;
153
+ let lastRow = -1;
154
+ return (downloadedBytes, totalBytes) => {
155
+ const percentage = downloadedBytes / totalBytes;
156
+ const row = Math.floor(totalRows * percentage);
157
+ if (row > lastRow) {
158
+ lastRow = row;
159
+ const percentageString = String(percentage * 100 | 0).padStart(3);
160
+ // eslint-disable-next-line no-console
161
+ console.log(`|${'■'.repeat(row * stepWidth)}${' '.repeat((totalRows - row) * stepWidth)}| ${percentageString}% of ${toMegabytes(totalBytes)}`);
162
+ }
163
+ };
164
+ }
165
+ function toMegabytes(bytes) {
166
+ const mb = bytes / 1024 / 1024;
167
+ return `${Math.round(mb * 10) / 10} MiB`;
168
+ }