patchright-bun-core 1.58.0 → 1.58.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 (358) hide show
  1. package/README.md +2 -2
  2. package/ThirdPartyNotices.txt +4075 -4075
  3. package/bin/install_media_pack.ps1 +5 -5
  4. package/bin/install_webkit_wsl.ps1 +32 -32
  5. package/bin/reinstall_chrome_beta_linux.sh +42 -42
  6. package/bin/reinstall_chrome_beta_mac.sh +13 -13
  7. package/bin/reinstall_chrome_beta_win.ps1 +24 -24
  8. package/bin/reinstall_chrome_stable_linux.sh +42 -42
  9. package/bin/reinstall_chrome_stable_mac.sh +12 -12
  10. package/bin/reinstall_chrome_stable_win.ps1 +24 -24
  11. package/bin/reinstall_msedge_beta_linux.sh +48 -48
  12. package/bin/reinstall_msedge_beta_mac.sh +11 -11
  13. package/bin/reinstall_msedge_beta_win.ps1 +23 -23
  14. package/bin/reinstall_msedge_dev_linux.sh +48 -48
  15. package/bin/reinstall_msedge_dev_mac.sh +11 -11
  16. package/bin/reinstall_msedge_dev_win.ps1 +23 -23
  17. package/bin/reinstall_msedge_stable_linux.sh +48 -48
  18. package/bin/reinstall_msedge_stable_mac.sh +11 -11
  19. package/bin/reinstall_msedge_stable_win.ps1 +23 -23
  20. package/browsers.json +79 -79
  21. package/cli.js +18 -18
  22. package/index.d.ts +17 -17
  23. package/index.js +32 -32
  24. package/index.mjs +28 -28
  25. package/lib/androidServerImpl.js +65 -65
  26. package/lib/browserServerImpl.js +120 -120
  27. package/lib/cli/driver.js +97 -97
  28. package/lib/cli/program.js +589 -589
  29. package/lib/cli/programWithTestStub.js +74 -74
  30. package/lib/client/android.js +361 -361
  31. package/lib/client/api.js +137 -137
  32. package/lib/client/artifact.js +79 -79
  33. package/lib/client/browser.js +161 -161
  34. package/lib/client/browserContext.js +582 -582
  35. package/lib/client/browserType.js +185 -185
  36. package/lib/client/cdpSession.js +51 -51
  37. package/lib/client/channelOwner.js +194 -194
  38. package/lib/client/clientHelper.js +64 -64
  39. package/lib/client/clientInstrumentation.js +55 -55
  40. package/lib/client/clientStackTrace.js +69 -69
  41. package/lib/client/clock.js +68 -68
  42. package/lib/client/connection.js +318 -318
  43. package/lib/client/consoleMessage.js +58 -58
  44. package/lib/client/coverage.js +44 -44
  45. package/lib/client/dialog.js +56 -56
  46. package/lib/client/download.js +62 -62
  47. package/lib/client/electron.js +138 -138
  48. package/lib/client/elementHandle.js +284 -284
  49. package/lib/client/errors.js +77 -77
  50. package/lib/client/eventEmitter.js +314 -314
  51. package/lib/client/events.js +103 -103
  52. package/lib/client/fetch.js +368 -368
  53. package/lib/client/fileChooser.js +46 -46
  54. package/lib/client/fileUtils.js +34 -34
  55. package/lib/client/frame.js +409 -409
  56. package/lib/client/harRouter.js +87 -87
  57. package/lib/client/input.js +84 -84
  58. package/lib/client/jsHandle.js +109 -109
  59. package/lib/client/jsonPipe.js +39 -39
  60. package/lib/client/localUtils.js +60 -60
  61. package/lib/client/locator.js +369 -369
  62. package/lib/client/network.js +747 -747
  63. package/lib/client/page.js +745 -745
  64. package/lib/client/pageAgent.js +64 -64
  65. package/lib/client/platform.js +77 -77
  66. package/lib/client/playwright.js +71 -71
  67. package/lib/client/selectors.js +55 -55
  68. package/lib/client/stream.js +39 -39
  69. package/lib/client/timeoutSettings.js +79 -79
  70. package/lib/client/tracing.js +119 -119
  71. package/lib/client/types.js +28 -28
  72. package/lib/client/video.js +59 -59
  73. package/lib/client/waiter.js +142 -142
  74. package/lib/client/webError.js +39 -39
  75. package/lib/client/webSocket.js +93 -93
  76. package/lib/client/worker.js +85 -85
  77. package/lib/client/writableStream.js +39 -39
  78. package/lib/generated/bindingsControllerSource.js +28 -28
  79. package/lib/generated/clockSource.js +28 -28
  80. package/lib/generated/injectedScriptSource.js +28 -28
  81. package/lib/generated/pollingRecorderSource.js +28 -28
  82. package/lib/generated/storageScriptSource.js +28 -28
  83. package/lib/generated/utilityScriptSource.js +28 -28
  84. package/lib/generated/webSocketMockSource.js +336 -336
  85. package/lib/inProcessFactory.js +60 -60
  86. package/lib/inprocess.js +3 -3
  87. package/lib/mcpBundle.js +84 -84
  88. package/lib/mcpBundleImpl/index.js +147 -147
  89. package/lib/outofprocess.js +76 -76
  90. package/lib/protocol/serializers.js +197 -197
  91. package/lib/protocol/validator.js +2969 -2969
  92. package/lib/protocol/validatorPrimitives.js +193 -193
  93. package/lib/remote/playwrightConnection.js +129 -129
  94. package/lib/remote/playwrightServer.js +334 -334
  95. package/lib/server/agent/actionRunner.js +335 -335
  96. package/lib/server/agent/actions.js +128 -128
  97. package/lib/server/agent/codegen.js +111 -111
  98. package/lib/server/agent/context.js +150 -150
  99. package/lib/server/agent/expectTools.js +156 -156
  100. package/lib/server/agent/pageAgent.js +204 -204
  101. package/lib/server/agent/performTools.js +262 -262
  102. package/lib/server/agent/tool.js +109 -109
  103. package/lib/server/android/android.js +465 -465
  104. package/lib/server/android/backendAdb.js +177 -177
  105. package/lib/server/artifact.js +127 -127
  106. package/lib/server/bidi/bidiBrowser.js +549 -549
  107. package/lib/server/bidi/bidiChromium.js +149 -148
  108. package/lib/server/bidi/bidiConnection.js +213 -213
  109. package/lib/server/bidi/bidiDeserializer.js +116 -116
  110. package/lib/server/bidi/bidiExecutionContext.js +267 -267
  111. package/lib/server/bidi/bidiFirefox.js +128 -128
  112. package/lib/server/bidi/bidiInput.js +146 -146
  113. package/lib/server/bidi/bidiNetworkManager.js +383 -383
  114. package/lib/server/bidi/bidiOverCdp.js +102 -102
  115. package/lib/server/bidi/bidiPage.js +583 -583
  116. package/lib/server/bidi/bidiPdf.js +106 -106
  117. package/lib/server/bidi/third_party/bidiCommands.d.js +22 -22
  118. package/lib/server/bidi/third_party/bidiKeyboard.js +256 -256
  119. package/lib/server/bidi/third_party/bidiProtocol.js +24 -24
  120. package/lib/server/bidi/third_party/bidiProtocolCore.js +180 -180
  121. package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -42
  122. package/lib/server/bidi/third_party/bidiSerializer.js +148 -148
  123. package/lib/server/bidi/third_party/firefoxPrefs.js +259 -259
  124. package/lib/server/browser.js +149 -149
  125. package/lib/server/browserContext.js +702 -702
  126. package/lib/server/browserType.js +336 -336
  127. package/lib/server/callLog.js +82 -82
  128. package/lib/server/chromium/chromium.js +397 -395
  129. package/lib/server/chromium/chromiumSwitches.js +104 -104
  130. package/lib/server/chromium/crBrowser.js +520 -511
  131. package/lib/server/chromium/crConnection.js +197 -197
  132. package/lib/server/chromium/crCoverage.js +235 -235
  133. package/lib/server/chromium/crDevTools.js +111 -111
  134. package/lib/server/chromium/crDragDrop.js +131 -131
  135. package/lib/server/chromium/crExecutionContext.js +146 -146
  136. package/lib/server/chromium/crInput.js +187 -187
  137. package/lib/server/chromium/crNetworkManager.js +707 -707
  138. package/lib/server/chromium/crPage.js +1001 -1001
  139. package/lib/server/chromium/crPdf.js +121 -121
  140. package/lib/server/chromium/crProtocolHelper.js +145 -145
  141. package/lib/server/chromium/crServiceWorker.js +136 -136
  142. package/lib/server/chromium/defaultFontFamilies.js +162 -162
  143. package/lib/server/chromium/protocol.d.js +16 -16
  144. package/lib/server/clock.js +149 -149
  145. package/lib/server/codegen/csharp.js +327 -327
  146. package/lib/server/codegen/java.js +274 -274
  147. package/lib/server/codegen/javascript.js +247 -247
  148. package/lib/server/codegen/jsonl.js +52 -52
  149. package/lib/server/codegen/language.js +132 -132
  150. package/lib/server/codegen/languages.js +68 -68
  151. package/lib/server/codegen/python.js +279 -279
  152. package/lib/server/codegen/types.js +16 -16
  153. package/lib/server/console.js +57 -57
  154. package/lib/server/cookieStore.js +206 -206
  155. package/lib/server/debugController.js +191 -191
  156. package/lib/server/debugger.js +119 -119
  157. package/lib/server/deviceDescriptors.js +39 -39
  158. package/lib/server/deviceDescriptorsSource.json +1778 -1778
  159. package/lib/server/dialog.js +116 -116
  160. package/lib/server/dispatchers/androidDispatcher.js +325 -325
  161. package/lib/server/dispatchers/artifactDispatcher.js +118 -118
  162. package/lib/server/dispatchers/browserContextDispatcher.js +384 -384
  163. package/lib/server/dispatchers/browserDispatcher.js +118 -118
  164. package/lib/server/dispatchers/browserTypeDispatcher.js +64 -64
  165. package/lib/server/dispatchers/cdpSessionDispatcher.js +44 -44
  166. package/lib/server/dispatchers/debugControllerDispatcher.js +78 -78
  167. package/lib/server/dispatchers/dialogDispatcher.js +47 -47
  168. package/lib/server/dispatchers/dispatcher.js +364 -364
  169. package/lib/server/dispatchers/electronDispatcher.js +89 -89
  170. package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -181
  171. package/lib/server/dispatchers/frameDispatcher.js +227 -227
  172. package/lib/server/dispatchers/jsHandleDispatcher.js +85 -85
  173. package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -58
  174. package/lib/server/dispatchers/localUtilsDispatcher.js +149 -149
  175. package/lib/server/dispatchers/networkDispatchers.js +213 -213
  176. package/lib/server/dispatchers/pageAgentDispatcher.js +96 -96
  177. package/lib/server/dispatchers/pageDispatcher.js +393 -393
  178. package/lib/server/dispatchers/playwrightDispatcher.js +108 -108
  179. package/lib/server/dispatchers/streamDispatcher.js +67 -67
  180. package/lib/server/dispatchers/tracingDispatcher.js +68 -68
  181. package/lib/server/dispatchers/webSocketRouteDispatcher.js +165 -165
  182. package/lib/server/dispatchers/writableStreamDispatcher.js +79 -79
  183. package/lib/server/dom.js +815 -815
  184. package/lib/server/download.js +70 -70
  185. package/lib/server/electron/electron.js +273 -273
  186. package/lib/server/electron/loader.js +29 -29
  187. package/lib/server/errors.js +69 -69
  188. package/lib/server/fetch.js +621 -621
  189. package/lib/server/fileChooser.js +43 -43
  190. package/lib/server/fileUploadUtils.js +84 -84
  191. package/lib/server/firefox/ffBrowser.js +418 -418
  192. package/lib/server/firefox/ffConnection.js +142 -142
  193. package/lib/server/firefox/ffExecutionContext.js +150 -150
  194. package/lib/server/firefox/ffInput.js +159 -159
  195. package/lib/server/firefox/ffNetworkManager.js +256 -256
  196. package/lib/server/firefox/ffPage.js +497 -497
  197. package/lib/server/firefox/firefox.js +114 -114
  198. package/lib/server/firefox/protocol.d.js +16 -16
  199. package/lib/server/formData.js +147 -147
  200. package/lib/server/frameSelectors.js +160 -160
  201. package/lib/server/frames.js +1471 -1471
  202. package/lib/server/har/harRecorder.js +147 -147
  203. package/lib/server/har/harTracer.js +607 -607
  204. package/lib/server/harBackend.js +157 -157
  205. package/lib/server/helper.js +96 -96
  206. package/lib/server/index.js +58 -58
  207. package/lib/server/input.js +277 -277
  208. package/lib/server/instrumentation.js +72 -72
  209. package/lib/server/javascript.js +291 -291
  210. package/lib/server/launchApp.js +128 -128
  211. package/lib/server/localUtils.js +214 -214
  212. package/lib/server/macEditingCommands.js +143 -143
  213. package/lib/server/network.js +667 -667
  214. package/lib/server/page.js +830 -830
  215. package/lib/server/pipeTransport.js +89 -89
  216. package/lib/server/playwright.js +69 -69
  217. package/lib/server/progress.js +132 -132
  218. package/lib/server/protocolError.js +52 -52
  219. package/lib/server/recorder/chat.js +161 -161
  220. package/lib/server/recorder/recorderApp.js +366 -366
  221. package/lib/server/recorder/recorderRunner.js +138 -138
  222. package/lib/server/recorder/recorderSignalProcessor.js +83 -83
  223. package/lib/server/recorder/recorderUtils.js +157 -157
  224. package/lib/server/recorder/throttledFile.js +57 -57
  225. package/lib/server/recorder.js +499 -499
  226. package/lib/server/registry/browserFetcher.js +177 -177
  227. package/lib/server/registry/dependencies.js +371 -371
  228. package/lib/server/registry/index.js +1422 -1422
  229. package/lib/server/registry/nativeDeps.js +1280 -1280
  230. package/lib/server/registry/oopDownloadBrowserMain.js +127 -127
  231. package/lib/server/screencast.js +190 -190
  232. package/lib/server/screenshotter.js +333 -333
  233. package/lib/server/selectors.js +112 -112
  234. package/lib/server/socksClientCertificatesInterceptor.js +383 -383
  235. package/lib/server/socksInterceptor.js +95 -95
  236. package/lib/server/trace/recorder/snapshotter.js +147 -147
  237. package/lib/server/trace/recorder/snapshotterInjected.js +561 -561
  238. package/lib/server/trace/recorder/tracing.js +604 -604
  239. package/lib/server/trace/viewer/traceParser.js +72 -72
  240. package/lib/server/trace/viewer/traceViewer.js +245 -245
  241. package/lib/server/transport.js +254 -254
  242. package/lib/server/types.js +28 -28
  243. package/lib/server/usKeyboardLayout.js +145 -145
  244. package/lib/server/utils/ascii.js +44 -44
  245. package/lib/server/utils/comparators.js +139 -139
  246. package/lib/server/utils/crypto.js +216 -216
  247. package/lib/server/utils/debug.js +42 -42
  248. package/lib/server/utils/debugLogger.js +122 -122
  249. package/lib/server/utils/env.js +73 -73
  250. package/lib/server/utils/eventsHelper.js +39 -39
  251. package/lib/server/utils/expectUtils.js +123 -123
  252. package/lib/server/utils/fileUtils.js +191 -191
  253. package/lib/server/utils/happyEyeballs.js +207 -207
  254. package/lib/server/utils/hostPlatform.js +138 -123
  255. package/lib/server/utils/httpServer.js +203 -203
  256. package/lib/server/utils/imageUtils.js +141 -141
  257. package/lib/server/utils/image_tools/colorUtils.js +89 -89
  258. package/lib/server/utils/image_tools/compare.js +109 -109
  259. package/lib/server/utils/image_tools/imageChannel.js +78 -78
  260. package/lib/server/utils/image_tools/stats.js +102 -102
  261. package/lib/server/utils/linuxUtils.js +71 -71
  262. package/lib/server/utils/network.js +242 -242
  263. package/lib/server/utils/nodePlatform.js +154 -154
  264. package/lib/server/utils/pipeTransport.js +84 -84
  265. package/lib/server/utils/processLauncher.js +241 -241
  266. package/lib/server/utils/profiler.js +65 -65
  267. package/lib/server/utils/socksProxy.js +511 -511
  268. package/lib/server/utils/spawnAsync.js +41 -41
  269. package/lib/server/utils/task.js +51 -51
  270. package/lib/server/utils/userAgent.js +98 -98
  271. package/lib/server/utils/wsServer.js +121 -121
  272. package/lib/server/utils/zipFile.js +74 -74
  273. package/lib/server/utils/zones.js +57 -57
  274. package/lib/server/videoRecorder.js +124 -124
  275. package/lib/server/webkit/protocol.d.js +16 -16
  276. package/lib/server/webkit/webkit.js +108 -108
  277. package/lib/server/webkit/wkBrowser.js +335 -335
  278. package/lib/server/webkit/wkConnection.js +144 -144
  279. package/lib/server/webkit/wkExecutionContext.js +154 -154
  280. package/lib/server/webkit/wkInput.js +181 -181
  281. package/lib/server/webkit/wkInterceptableRequest.js +197 -197
  282. package/lib/server/webkit/wkPage.js +1159 -1158
  283. package/lib/server/webkit/wkProvisionalPage.js +83 -83
  284. package/lib/server/webkit/wkWorkers.js +105 -105
  285. package/lib/third_party/pixelmatch.js +255 -255
  286. package/lib/utils/isomorphic/ariaSnapshot.js +455 -455
  287. package/lib/utils/isomorphic/assert.js +31 -31
  288. package/lib/utils/isomorphic/colors.js +72 -72
  289. package/lib/utils/isomorphic/cssParser.js +245 -245
  290. package/lib/utils/isomorphic/cssTokenizer.js +1051 -1051
  291. package/lib/utils/isomorphic/headers.js +53 -53
  292. package/lib/utils/isomorphic/locatorGenerators.js +689 -689
  293. package/lib/utils/isomorphic/locatorParser.js +176 -176
  294. package/lib/utils/isomorphic/locatorUtils.js +81 -81
  295. package/lib/utils/isomorphic/lruCache.js +51 -51
  296. package/lib/utils/isomorphic/manualPromise.js +114 -114
  297. package/lib/utils/isomorphic/mimeType.js +459 -459
  298. package/lib/utils/isomorphic/multimap.js +80 -80
  299. package/lib/utils/isomorphic/protocolFormatter.js +81 -81
  300. package/lib/utils/isomorphic/protocolMetainfo.js +330 -330
  301. package/lib/utils/isomorphic/rtti.js +43 -43
  302. package/lib/utils/isomorphic/selectorParser.js +386 -386
  303. package/lib/utils/isomorphic/semaphore.js +54 -54
  304. package/lib/utils/isomorphic/stackTrace.js +158 -158
  305. package/lib/utils/isomorphic/stringUtils.js +204 -204
  306. package/lib/utils/isomorphic/time.js +49 -49
  307. package/lib/utils/isomorphic/timeoutRunner.js +66 -66
  308. package/lib/utils/isomorphic/trace/entries.js +16 -16
  309. package/lib/utils/isomorphic/trace/snapshotRenderer.js +499 -499
  310. package/lib/utils/isomorphic/trace/snapshotServer.js +120 -120
  311. package/lib/utils/isomorphic/trace/snapshotStorage.js +89 -89
  312. package/lib/utils/isomorphic/trace/traceLoader.js +131 -131
  313. package/lib/utils/isomorphic/trace/traceModel.js +365 -365
  314. package/lib/utils/isomorphic/trace/traceModernizer.js +400 -400
  315. package/lib/utils/isomorphic/trace/versions/traceV3.js +16 -16
  316. package/lib/utils/isomorphic/trace/versions/traceV4.js +16 -16
  317. package/lib/utils/isomorphic/trace/versions/traceV5.js +16 -16
  318. package/lib/utils/isomorphic/trace/versions/traceV6.js +16 -16
  319. package/lib/utils/isomorphic/trace/versions/traceV7.js +16 -16
  320. package/lib/utils/isomorphic/trace/versions/traceV8.js +16 -16
  321. package/lib/utils/isomorphic/traceUtils.js +58 -58
  322. package/lib/utils/isomorphic/types.js +16 -16
  323. package/lib/utils/isomorphic/urlMatch.js +190 -190
  324. package/lib/utils/isomorphic/utilityScriptSerializers.js +251 -251
  325. package/lib/utils/isomorphic/yaml.js +84 -84
  326. package/lib/utils.js +111 -111
  327. package/lib/utilsBundle.js +109 -109
  328. package/lib/utilsBundleImpl/index.js +218 -218
  329. package/lib/utilsBundleImpl/xdg-open +1066 -1066
  330. package/lib/vite/htmlReport/index.html +84 -84
  331. package/lib/vite/recorder/assets/codeMirrorModule-DYBRYzYX.css +1 -1
  332. package/lib/vite/recorder/assets/codeMirrorModule-DadYNm1I.js +32 -32
  333. package/lib/vite/recorder/assets/index-BSjZa4pk.css +1 -1
  334. package/lib/vite/recorder/assets/index-BhTWtUlo.js +193 -193
  335. package/lib/vite/recorder/index.html +29 -29
  336. package/lib/vite/recorder/playwright-logo.svg +9 -9
  337. package/lib/vite/traceViewer/assets/codeMirrorModule-a5XoALAZ.js +32 -32
  338. package/lib/vite/traceViewer/assets/defaultSettingsView-CJSZINFr.js +266 -266
  339. package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -9
  340. package/lib/vite/traceViewer/codeMirrorModule.DYBRYzYX.css +1 -1
  341. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +1 -1
  342. package/lib/vite/traceViewer/{index.Bk2uYQRV.js → index.BDwrLSGN.js} +2 -2
  343. package/lib/vite/traceViewer/index.BVu7tZDe.css +1 -1
  344. package/lib/vite/traceViewer/index.html +43 -43
  345. package/lib/vite/traceViewer/manifest.webmanifest +16 -16
  346. package/lib/vite/traceViewer/playwright-logo.svg +9 -9
  347. package/lib/vite/traceViewer/snapshot.html +21 -21
  348. package/lib/vite/traceViewer/sw.bundle.js +5 -5
  349. package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -1
  350. package/lib/vite/traceViewer/uiMode.CQJ9SCIQ.js +5 -5
  351. package/lib/vite/traceViewer/uiMode.html +17 -17
  352. package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -32
  353. package/lib/zipBundle.js +34 -34
  354. package/lib/zipBundleImpl.js +5 -5
  355. package/package.json +1 -1
  356. package/types/protocol.d.ts +23824 -23824
  357. package/types/structs.d.ts +45 -45
  358. package/types/types.d.ts +22843 -22843
@@ -1,604 +1,604 @@
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 tracing_exports = {};
30
- __export(tracing_exports, {
31
- Tracing: () => Tracing
32
- });
33
- module.exports = __toCommonJS(tracing_exports);
34
- var import_fs = __toESM(require("fs"));
35
- var import_os = __toESM(require("os"));
36
- var import_path = __toESM(require("path"));
37
- var import_snapshotter = require("./snapshotter");
38
- var import_protocolMetainfo = require("../../../utils/isomorphic/protocolMetainfo");
39
- var import_assert = require("../../../utils/isomorphic/assert");
40
- var import_time = require("../../../utils/isomorphic/time");
41
- var import_eventsHelper = require("../../utils/eventsHelper");
42
- var import_crypto = require("../../utils/crypto");
43
- var import_userAgent = require("../../utils/userAgent");
44
- var import_artifact = require("../../artifact");
45
- var import_browserContext = require("../../browserContext");
46
- var import_dispatcher = require("../../dispatchers/dispatcher");
47
- var import_errors = require("../../errors");
48
- var import_fileUtils = require("../../utils/fileUtils");
49
- var import_harTracer = require("../../har/harTracer");
50
- var import_instrumentation = require("../../instrumentation");
51
- var import_page = require("../../page");
52
- var import_progress = require("../../progress");
53
- const version = 8;
54
- const kScreencastOptions = { width: 800, height: 600, quality: 90 };
55
- class Tracing extends import_instrumentation.SdkObject {
56
- constructor(context, tracesDir) {
57
- super(context, "tracing");
58
- this._fs = new import_fileUtils.SerializedFS();
59
- this._screencastListeners = [];
60
- this._eventListeners = [];
61
- this._isStopping = false;
62
- this._allResources = /* @__PURE__ */ new Set();
63
- this._pendingHarEntries = /* @__PURE__ */ new Set();
64
- this._context = context;
65
- this._precreatedTracesDir = tracesDir;
66
- this._harTracer = new import_harTracer.HarTracer(context, null, this, {
67
- content: "attach",
68
- includeTraceInfo: true,
69
- recordRequestOverrides: false,
70
- waitForContentOnStop: false
71
- });
72
- const testIdAttributeName = "selectors" in context ? context.selectors().testIdAttributeName() : void 0;
73
- this._contextCreatedEvent = {
74
- version,
75
- type: "context-options",
76
- origin: "library",
77
- browserName: "",
78
- playwrightVersion: (0, import_userAgent.getPlaywrightVersion)(),
79
- options: {},
80
- platform: process.platform,
81
- wallTime: 0,
82
- monotonicTime: 0,
83
- sdkLanguage: this._sdkLanguage(),
84
- testIdAttributeName,
85
- contextId: context.guid
86
- };
87
- if (context instanceof import_browserContext.BrowserContext) {
88
- this._snapshotter = new import_snapshotter.Snapshotter(context, this);
89
- (0, import_assert.assert)(tracesDir, "tracesDir must be specified for BrowserContext");
90
- this._contextCreatedEvent.browserName = context._browser.options.name;
91
- this._contextCreatedEvent.channel = context._browser.options.channel;
92
- this._contextCreatedEvent.options = context._options;
93
- }
94
- }
95
- _sdkLanguage() {
96
- return this._context instanceof import_browserContext.BrowserContext ? this._context._browser.sdkLanguage() : this._context.attribution.playwright.options.sdkLanguage;
97
- }
98
- async resetForReuse(progress) {
99
- await this.stopChunk(progress, { mode: "discard" }).catch(() => {
100
- });
101
- await this.stop(progress);
102
- if (this._snapshotter)
103
- await progress.race(this._snapshotter.resetForReuse());
104
- }
105
- start(options) {
106
- if (this._isStopping)
107
- throw new Error("Cannot start tracing while stopping");
108
- if (this._state)
109
- throw new Error("Tracing has been already started");
110
- this._contextCreatedEvent.sdkLanguage = this._sdkLanguage();
111
- const traceName = options.name || (0, import_crypto.createGuid)();
112
- const tracesDir = this._createTracesDirIfNeeded();
113
- this._state = {
114
- options,
115
- traceName,
116
- tracesDir,
117
- traceFile: import_path.default.join(tracesDir, traceName + ".trace"),
118
- networkFile: import_path.default.join(tracesDir, traceName + ".network"),
119
- resourcesDir: import_path.default.join(tracesDir, "resources"),
120
- chunkOrdinal: 0,
121
- traceSha1s: /* @__PURE__ */ new Set(),
122
- networkSha1s: /* @__PURE__ */ new Set(),
123
- recording: false,
124
- callIds: /* @__PURE__ */ new Set(),
125
- groupStack: []
126
- };
127
- this._fs.mkdir(this._state.resourcesDir);
128
- this._fs.writeFile(this._state.networkFile, "");
129
- if (options.snapshots)
130
- this._harTracer.start({ omitScripts: !options.live });
131
- }
132
- async startChunk(progress, options = {}) {
133
- if (this._state && this._state.recording)
134
- await this.stopChunk(progress, { mode: "discard" });
135
- if (!this._state)
136
- throw new Error("Must start tracing before starting a new chunk");
137
- if (this._isStopping)
138
- throw new Error("Cannot start a trace chunk while stopping");
139
- this._state.recording = true;
140
- this._state.callIds.clear();
141
- const preserveNetworkResources = this._context instanceof import_browserContext.BrowserContext;
142
- if (options.name && options.name !== this._state.traceName)
143
- this._changeTraceName(this._state, options.name, preserveNetworkResources);
144
- else
145
- this._allocateNewTraceFile(this._state);
146
- if (!preserveNetworkResources)
147
- this._fs.writeFile(this._state.networkFile, "");
148
- this._fs.mkdir(import_path.default.dirname(this._state.traceFile));
149
- const event = {
150
- ...this._contextCreatedEvent,
151
- title: options.title,
152
- wallTime: Date.now(),
153
- monotonicTime: (0, import_time.monotonicTime)()
154
- };
155
- this._appendTraceEvent(event);
156
- this._context.instrumentation.addListener(this, this._context);
157
- this._eventListeners.push(
158
- import_eventsHelper.eventsHelper.addEventListener(this._context, import_browserContext.BrowserContext.Events.Console, this._onConsoleMessage.bind(this)),
159
- import_eventsHelper.eventsHelper.addEventListener(this._context, import_browserContext.BrowserContext.Events.PageError, this._onPageError.bind(this))
160
- );
161
- if (this._state.options.screenshots)
162
- this._startScreencast();
163
- if (this._state.options.snapshots)
164
- await this._snapshotter?.start();
165
- return { traceName: this._state.traceName };
166
- }
167
- _currentGroupId() {
168
- return this._state?.groupStack.length ? this._state.groupStack[this._state.groupStack.length - 1] : void 0;
169
- }
170
- group(name, location, metadata) {
171
- if (!this._state)
172
- return;
173
- const stackFrames = [];
174
- const { file, line, column } = location ?? metadata.location ?? {};
175
- if (file) {
176
- stackFrames.push({
177
- file,
178
- line: line ?? 0,
179
- column: column ?? 0
180
- });
181
- }
182
- const event = {
183
- type: "before",
184
- callId: metadata.id,
185
- startTime: metadata.startTime,
186
- title: name,
187
- class: "Tracing",
188
- method: "tracingGroup",
189
- params: {},
190
- stepId: metadata.stepId,
191
- stack: stackFrames
192
- };
193
- if (this._currentGroupId())
194
- event.parentId = this._currentGroupId();
195
- this._state.groupStack.push(event.callId);
196
- this._appendTraceEvent(event);
197
- }
198
- groupEnd() {
199
- if (!this._state)
200
- return;
201
- const callId = this._state.groupStack.pop();
202
- if (!callId)
203
- return;
204
- const event = {
205
- type: "after",
206
- callId,
207
- endTime: (0, import_time.monotonicTime)()
208
- };
209
- this._appendTraceEvent(event);
210
- }
211
- _startScreencast() {
212
- if (!(this._context instanceof import_browserContext.BrowserContext))
213
- return;
214
- for (const page of this._context.pages())
215
- this._startScreencastInPage(page);
216
- this._screencastListeners.push(
217
- import_eventsHelper.eventsHelper.addEventListener(this._context, import_browserContext.BrowserContext.Events.Page, this._startScreencastInPage.bind(this))
218
- );
219
- }
220
- _stopScreencast() {
221
- import_eventsHelper.eventsHelper.removeEventListeners(this._screencastListeners);
222
- if (!(this._context instanceof import_browserContext.BrowserContext))
223
- return;
224
- for (const page of this._context.pages())
225
- page.screencast.setOptions(null);
226
- }
227
- _allocateNewTraceFile(state) {
228
- const suffix = state.chunkOrdinal ? `-chunk${state.chunkOrdinal}` : ``;
229
- state.chunkOrdinal++;
230
- state.traceFile = import_path.default.join(state.tracesDir, `${state.traceName}${suffix}.trace`);
231
- }
232
- _changeTraceName(state, name, preserveNetworkResources) {
233
- state.traceName = name;
234
- state.chunkOrdinal = 0;
235
- this._allocateNewTraceFile(state);
236
- const newNetworkFile = import_path.default.join(state.tracesDir, name + ".network");
237
- if (preserveNetworkResources)
238
- this._fs.copyFile(state.networkFile, newNetworkFile);
239
- state.networkFile = newNetworkFile;
240
- }
241
- async stop(progress) {
242
- if (!this._state)
243
- return;
244
- if (this._isStopping)
245
- throw new Error(`Tracing is already stopping`);
246
- if (this._state.recording)
247
- throw new Error(`Must stop trace file before stopping tracing`);
248
- this._closeAllGroups();
249
- this._harTracer.stop();
250
- this.flushHarEntries();
251
- const promise = progress ? progress.race(this._fs.syncAndGetError()) : this._fs.syncAndGetError();
252
- await promise.finally(() => {
253
- this._state = void 0;
254
- });
255
- }
256
- async deleteTmpTracesDir() {
257
- if (this._tracesTmpDir)
258
- await (0, import_fileUtils.removeFolders)([this._tracesTmpDir]);
259
- }
260
- _createTracesDirIfNeeded() {
261
- if (this._precreatedTracesDir)
262
- return this._precreatedTracesDir;
263
- this._tracesTmpDir = import_fs.default.mkdtempSync(import_path.default.join(import_os.default.tmpdir(), "playwright-tracing-"));
264
- return this._tracesTmpDir;
265
- }
266
- abort() {
267
- this._snapshotter?.dispose();
268
- this._harTracer.stop();
269
- }
270
- async flush() {
271
- this.abort();
272
- await this._fs.syncAndGetError();
273
- }
274
- _closeAllGroups() {
275
- while (this._currentGroupId())
276
- this.groupEnd();
277
- }
278
- async stopChunk(progress, params) {
279
- if (this._isStopping)
280
- throw new Error(`Tracing is already stopping`);
281
- this._isStopping = true;
282
- if (!this._state || !this._state.recording) {
283
- this._isStopping = false;
284
- if (params.mode !== "discard")
285
- throw new Error(`Must start tracing before stopping`);
286
- return {};
287
- }
288
- this._closeAllGroups();
289
- this._context.instrumentation.removeListener(this);
290
- import_eventsHelper.eventsHelper.removeEventListeners(this._eventListeners);
291
- if (this._state.options.screenshots)
292
- this._stopScreencast();
293
- if (this._state.options.snapshots)
294
- this._snapshotter?.stop();
295
- this.flushHarEntries();
296
- const newNetworkFile = import_path.default.join(this._state.tracesDir, this._state.traceName + `-pwnetcopy-${this._state.chunkOrdinal}.network`);
297
- const entries = [];
298
- entries.push({ name: "trace.trace", value: this._state.traceFile });
299
- entries.push({ name: "trace.network", value: newNetworkFile });
300
- for (const sha1 of /* @__PURE__ */ new Set([...this._state.traceSha1s, ...this._state.networkSha1s]))
301
- entries.push({ name: import_path.default.join("resources", sha1), value: import_path.default.join(this._state.resourcesDir, sha1) });
302
- this._state.traceSha1s = /* @__PURE__ */ new Set();
303
- if (params.mode === "discard") {
304
- this._isStopping = false;
305
- this._state.recording = false;
306
- return {};
307
- }
308
- this._fs.copyFile(this._state.networkFile, newNetworkFile);
309
- const zipFileName = this._state.traceFile + ".zip";
310
- if (params.mode === "archive")
311
- this._fs.zip(entries, zipFileName);
312
- const promise = progress ? progress.race(this._fs.syncAndGetError()) : this._fs.syncAndGetError();
313
- const error = await promise.catch((e) => e);
314
- this._isStopping = false;
315
- if (this._state)
316
- this._state.recording = false;
317
- if (error) {
318
- if (!(0, import_progress.isAbortError)(error) && this._context instanceof import_browserContext.BrowserContext && !this._context._browser.isConnected())
319
- return {};
320
- throw error;
321
- }
322
- if (params.mode === "entries")
323
- return { entries };
324
- const artifact = new import_artifact.Artifact(this._context, zipFileName);
325
- artifact.reportFinished();
326
- return { artifact };
327
- }
328
- async _captureSnapshot(snapshotName, sdkObject, metadata) {
329
- if (!snapshotName || !sdkObject.attribution.page)
330
- return;
331
- await this._snapshotter?.captureSnapshot(sdkObject.attribution.page, metadata.id, snapshotName).catch(() => {
332
- });
333
- }
334
- _shouldCaptureSnapshot(sdkObject, metadata) {
335
- return !!this._snapshotter?.started() && shouldCaptureSnapshot(metadata) && !!sdkObject.attribution.page;
336
- }
337
- onBeforeCall(sdkObject, metadata, parentId) {
338
- const event = createBeforeActionTraceEvent(metadata, parentId ?? this._currentGroupId());
339
- if (!event)
340
- return Promise.resolve();
341
- sdkObject.attribution.page?.screencast.temporarilyDisableThrottling();
342
- if (this._shouldCaptureSnapshot(sdkObject, metadata))
343
- event.beforeSnapshot = `before@${metadata.id}`;
344
- this._state?.callIds.add(metadata.id);
345
- this._appendTraceEvent(event);
346
- return this._captureSnapshot(event.beforeSnapshot, sdkObject, metadata);
347
- }
348
- onBeforeInputAction(sdkObject, metadata) {
349
- if (!this._state?.callIds.has(metadata.id))
350
- return Promise.resolve();
351
- const event = createInputActionTraceEvent(metadata);
352
- if (!event)
353
- return Promise.resolve();
354
- sdkObject.attribution.page?.screencast.temporarilyDisableThrottling();
355
- if (this._shouldCaptureSnapshot(sdkObject, metadata))
356
- event.inputSnapshot = `input@${metadata.id}`;
357
- this._appendTraceEvent(event);
358
- return this._captureSnapshot(event.inputSnapshot, sdkObject, metadata);
359
- }
360
- onCallLog(sdkObject, metadata, logName, message) {
361
- if (!this._state?.callIds.has(metadata.id))
362
- return;
363
- if (metadata.internal)
364
- return;
365
- if (logName !== "api")
366
- return;
367
- const event = createActionLogTraceEvent(metadata, message);
368
- if (event)
369
- this._appendTraceEvent(event);
370
- }
371
- onAfterCall(sdkObject, metadata) {
372
- if (!this._state?.callIds.has(metadata.id))
373
- return Promise.resolve();
374
- this._state?.callIds.delete(metadata.id);
375
- const event = createAfterActionTraceEvent(metadata);
376
- if (!event)
377
- return Promise.resolve();
378
- sdkObject.attribution.page?.screencast.temporarilyDisableThrottling();
379
- if (this._shouldCaptureSnapshot(sdkObject, metadata))
380
- event.afterSnapshot = `after@${metadata.id}`;
381
- this._appendTraceEvent(event);
382
- return this._captureSnapshot(event.afterSnapshot, sdkObject, metadata);
383
- }
384
- onEntryStarted(entry) {
385
- this._pendingHarEntries.add(entry);
386
- }
387
- onEntryFinished(entry) {
388
- this._pendingHarEntries.delete(entry);
389
- const event = { type: "resource-snapshot", snapshot: entry };
390
- const visited = visitTraceEvent(event, this._state.networkSha1s);
391
- this._fs.appendFile(
392
- this._state.networkFile,
393
- JSON.stringify(visited) + "\n",
394
- true
395
- /* flush */
396
- );
397
- }
398
- flushHarEntries() {
399
- const harLines = [];
400
- for (const entry of this._pendingHarEntries) {
401
- const event = { type: "resource-snapshot", snapshot: entry };
402
- const visited = visitTraceEvent(event, this._state.networkSha1s);
403
- harLines.push(JSON.stringify(visited));
404
- }
405
- this._pendingHarEntries.clear();
406
- if (harLines.length)
407
- this._fs.appendFile(
408
- this._state.networkFile,
409
- harLines.join("\n") + "\n",
410
- true
411
- /* flush */
412
- );
413
- }
414
- onContentBlob(sha1, buffer) {
415
- this._appendResource(sha1, buffer);
416
- }
417
- onSnapshotterBlob(blob) {
418
- this._appendResource(blob.sha1, blob.buffer);
419
- }
420
- onFrameSnapshot(snapshot) {
421
- this._appendTraceEvent({ type: "frame-snapshot", snapshot });
422
- }
423
- _onConsoleMessage(message) {
424
- const event = {
425
- type: "console",
426
- messageType: message.type(),
427
- text: message.text(),
428
- args: message.args().map((a) => ({ preview: a.toString(), value: a.rawValue() })),
429
- location: message.location(),
430
- time: (0, import_time.monotonicTime)(),
431
- pageId: message.page()?.guid
432
- };
433
- this._appendTraceEvent(event);
434
- }
435
- onDialog(dialog) {
436
- const event = {
437
- type: "event",
438
- time: (0, import_time.monotonicTime)(),
439
- class: "BrowserContext",
440
- method: "dialog",
441
- params: { pageId: dialog.page().guid, type: dialog.type(), message: dialog.message(), defaultValue: dialog.defaultValue() }
442
- };
443
- this._appendTraceEvent(event);
444
- }
445
- onDownload(page, download) {
446
- const event = {
447
- type: "event",
448
- time: (0, import_time.monotonicTime)(),
449
- class: "BrowserContext",
450
- method: "download",
451
- params: { pageId: page.guid, url: download.url, suggestedFilename: download.suggestedFilename() }
452
- };
453
- this._appendTraceEvent(event);
454
- }
455
- onPageOpen(page) {
456
- const event = {
457
- type: "event",
458
- time: (0, import_time.monotonicTime)(),
459
- class: "BrowserContext",
460
- method: "page",
461
- params: { pageId: page.guid, openerPageId: page.opener()?.guid }
462
- };
463
- this._appendTraceEvent(event);
464
- }
465
- onPageClose(page) {
466
- const event = {
467
- type: "event",
468
- time: (0, import_time.monotonicTime)(),
469
- class: "BrowserContext",
470
- method: "pageClosed",
471
- params: { pageId: page.guid }
472
- };
473
- this._appendTraceEvent(event);
474
- }
475
- _onPageError(error, page) {
476
- const event = {
477
- type: "event",
478
- time: (0, import_time.monotonicTime)(),
479
- class: "BrowserContext",
480
- method: "pageError",
481
- params: { error: (0, import_errors.serializeError)(error) },
482
- pageId: page.guid
483
- };
484
- this._appendTraceEvent(event);
485
- }
486
- _startScreencastInPage(page) {
487
- page.screencast.setOptions(kScreencastOptions);
488
- const prefix = page.guid;
489
- this._screencastListeners.push(
490
- import_eventsHelper.eventsHelper.addEventListener(page, import_page.Page.Events.ScreencastFrame, (params) => {
491
- const suffix = params.timestamp || Date.now();
492
- const sha1 = `${prefix}-${suffix}.jpeg`;
493
- const event = {
494
- type: "screencast-frame",
495
- pageId: page.guid,
496
- sha1,
497
- width: params.width,
498
- height: params.height,
499
- timestamp: (0, import_time.monotonicTime)(),
500
- frameSwapWallTime: params.frameSwapWallTime
501
- };
502
- this._appendResource(sha1, params.buffer);
503
- this._appendTraceEvent(event);
504
- })
505
- );
506
- }
507
- _appendTraceEvent(event) {
508
- const visited = visitTraceEvent(event, this._state.traceSha1s);
509
- const flush = this._state.options.live || event.type !== "event" && event.type !== "console" && event.type !== "log";
510
- this._fs.appendFile(this._state.traceFile, JSON.stringify(visited) + "\n", flush);
511
- }
512
- _appendResource(sha1, buffer) {
513
- if (this._allResources.has(sha1))
514
- return;
515
- this._allResources.add(sha1);
516
- const resourcePath = import_path.default.join(this._state.resourcesDir, sha1);
517
- this._fs.writeFile(
518
- resourcePath,
519
- buffer,
520
- true
521
- /* skipIfExists */
522
- );
523
- }
524
- }
525
- function visitTraceEvent(object, sha1s) {
526
- if (Array.isArray(object))
527
- return object.map((o) => visitTraceEvent(o, sha1s));
528
- if (object instanceof import_dispatcher.Dispatcher)
529
- return `<${object._type}>`;
530
- if (object instanceof Buffer)
531
- return `<Buffer>`;
532
- if (object instanceof Date)
533
- return object;
534
- if (typeof object === "object") {
535
- const result = {};
536
- for (const key in object) {
537
- if (key === "sha1" || key === "_sha1" || key.endsWith("Sha1")) {
538
- const sha1 = object[key];
539
- if (sha1)
540
- sha1s.add(sha1);
541
- }
542
- result[key] = visitTraceEvent(object[key], sha1s);
543
- }
544
- return result;
545
- }
546
- return object;
547
- }
548
- function shouldCaptureSnapshot(metadata) {
549
- const metainfo = import_protocolMetainfo.methodMetainfo.get(metadata.type + "." + metadata.method);
550
- return !!metainfo?.snapshot;
551
- }
552
- function createBeforeActionTraceEvent(metadata, parentId) {
553
- if (metadata.internal || metadata.method.startsWith("tracing"))
554
- return null;
555
- const event = {
556
- type: "before",
557
- callId: metadata.id,
558
- startTime: metadata.startTime,
559
- title: metadata.title,
560
- class: metadata.type,
561
- method: metadata.method,
562
- params: metadata.params,
563
- stepId: metadata.stepId,
564
- pageId: metadata.pageId
565
- };
566
- if (parentId)
567
- event.parentId = parentId;
568
- return event;
569
- }
570
- function createInputActionTraceEvent(metadata) {
571
- if (metadata.internal || metadata.method.startsWith("tracing"))
572
- return null;
573
- return {
574
- type: "input",
575
- callId: metadata.id,
576
- point: metadata.point
577
- };
578
- }
579
- function createActionLogTraceEvent(metadata, message) {
580
- if (metadata.internal || metadata.method.startsWith("tracing"))
581
- return null;
582
- return {
583
- type: "log",
584
- callId: metadata.id,
585
- time: (0, import_time.monotonicTime)(),
586
- message
587
- };
588
- }
589
- function createAfterActionTraceEvent(metadata) {
590
- if (metadata.internal || metadata.method.startsWith("tracing"))
591
- return null;
592
- return {
593
- type: "after",
594
- callId: metadata.id,
595
- endTime: metadata.endTime,
596
- error: metadata.error?.error,
597
- result: metadata.result,
598
- point: metadata.point
599
- };
600
- }
601
- // Annotate the CommonJS export names for ESM import in node:
602
- 0 && (module.exports = {
603
- Tracing
604
- });
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 tracing_exports = {};
30
+ __export(tracing_exports, {
31
+ Tracing: () => Tracing
32
+ });
33
+ module.exports = __toCommonJS(tracing_exports);
34
+ var import_fs = __toESM(require("fs"));
35
+ var import_os = __toESM(require("os"));
36
+ var import_path = __toESM(require("path"));
37
+ var import_snapshotter = require("./snapshotter");
38
+ var import_protocolMetainfo = require("../../../utils/isomorphic/protocolMetainfo");
39
+ var import_assert = require("../../../utils/isomorphic/assert");
40
+ var import_time = require("../../../utils/isomorphic/time");
41
+ var import_eventsHelper = require("../../utils/eventsHelper");
42
+ var import_crypto = require("../../utils/crypto");
43
+ var import_userAgent = require("../../utils/userAgent");
44
+ var import_artifact = require("../../artifact");
45
+ var import_browserContext = require("../../browserContext");
46
+ var import_dispatcher = require("../../dispatchers/dispatcher");
47
+ var import_errors = require("../../errors");
48
+ var import_fileUtils = require("../../utils/fileUtils");
49
+ var import_harTracer = require("../../har/harTracer");
50
+ var import_instrumentation = require("../../instrumentation");
51
+ var import_page = require("../../page");
52
+ var import_progress = require("../../progress");
53
+ const version = 8;
54
+ const kScreencastOptions = { width: 800, height: 600, quality: 90 };
55
+ class Tracing extends import_instrumentation.SdkObject {
56
+ constructor(context, tracesDir) {
57
+ super(context, "tracing");
58
+ this._fs = new import_fileUtils.SerializedFS();
59
+ this._screencastListeners = [];
60
+ this._eventListeners = [];
61
+ this._isStopping = false;
62
+ this._allResources = /* @__PURE__ */ new Set();
63
+ this._pendingHarEntries = /* @__PURE__ */ new Set();
64
+ this._context = context;
65
+ this._precreatedTracesDir = tracesDir;
66
+ this._harTracer = new import_harTracer.HarTracer(context, null, this, {
67
+ content: "attach",
68
+ includeTraceInfo: true,
69
+ recordRequestOverrides: false,
70
+ waitForContentOnStop: false
71
+ });
72
+ const testIdAttributeName = "selectors" in context ? context.selectors().testIdAttributeName() : void 0;
73
+ this._contextCreatedEvent = {
74
+ version,
75
+ type: "context-options",
76
+ origin: "library",
77
+ browserName: "",
78
+ playwrightVersion: (0, import_userAgent.getPlaywrightVersion)(),
79
+ options: {},
80
+ platform: process.platform,
81
+ wallTime: 0,
82
+ monotonicTime: 0,
83
+ sdkLanguage: this._sdkLanguage(),
84
+ testIdAttributeName,
85
+ contextId: context.guid
86
+ };
87
+ if (context instanceof import_browserContext.BrowserContext) {
88
+ this._snapshotter = new import_snapshotter.Snapshotter(context, this);
89
+ (0, import_assert.assert)(tracesDir, "tracesDir must be specified for BrowserContext");
90
+ this._contextCreatedEvent.browserName = context._browser.options.name;
91
+ this._contextCreatedEvent.channel = context._browser.options.channel;
92
+ this._contextCreatedEvent.options = context._options;
93
+ }
94
+ }
95
+ _sdkLanguage() {
96
+ return this._context instanceof import_browserContext.BrowserContext ? this._context._browser.sdkLanguage() : this._context.attribution.playwright.options.sdkLanguage;
97
+ }
98
+ async resetForReuse(progress) {
99
+ await this.stopChunk(progress, { mode: "discard" }).catch(() => {
100
+ });
101
+ await this.stop(progress);
102
+ if (this._snapshotter)
103
+ await progress.race(this._snapshotter.resetForReuse());
104
+ }
105
+ start(options) {
106
+ if (this._isStopping)
107
+ throw new Error("Cannot start tracing while stopping");
108
+ if (this._state)
109
+ throw new Error("Tracing has been already started");
110
+ this._contextCreatedEvent.sdkLanguage = this._sdkLanguage();
111
+ const traceName = options.name || (0, import_crypto.createGuid)();
112
+ const tracesDir = this._createTracesDirIfNeeded();
113
+ this._state = {
114
+ options,
115
+ traceName,
116
+ tracesDir,
117
+ traceFile: import_path.default.join(tracesDir, traceName + ".trace"),
118
+ networkFile: import_path.default.join(tracesDir, traceName + ".network"),
119
+ resourcesDir: import_path.default.join(tracesDir, "resources"),
120
+ chunkOrdinal: 0,
121
+ traceSha1s: /* @__PURE__ */ new Set(),
122
+ networkSha1s: /* @__PURE__ */ new Set(),
123
+ recording: false,
124
+ callIds: /* @__PURE__ */ new Set(),
125
+ groupStack: []
126
+ };
127
+ this._fs.mkdir(this._state.resourcesDir);
128
+ this._fs.writeFile(this._state.networkFile, "");
129
+ if (options.snapshots)
130
+ this._harTracer.start({ omitScripts: !options.live });
131
+ }
132
+ async startChunk(progress, options = {}) {
133
+ if (this._state && this._state.recording)
134
+ await this.stopChunk(progress, { mode: "discard" });
135
+ if (!this._state)
136
+ throw new Error("Must start tracing before starting a new chunk");
137
+ if (this._isStopping)
138
+ throw new Error("Cannot start a trace chunk while stopping");
139
+ this._state.recording = true;
140
+ this._state.callIds.clear();
141
+ const preserveNetworkResources = this._context instanceof import_browserContext.BrowserContext;
142
+ if (options.name && options.name !== this._state.traceName)
143
+ this._changeTraceName(this._state, options.name, preserveNetworkResources);
144
+ else
145
+ this._allocateNewTraceFile(this._state);
146
+ if (!preserveNetworkResources)
147
+ this._fs.writeFile(this._state.networkFile, "");
148
+ this._fs.mkdir(import_path.default.dirname(this._state.traceFile));
149
+ const event = {
150
+ ...this._contextCreatedEvent,
151
+ title: options.title,
152
+ wallTime: Date.now(),
153
+ monotonicTime: (0, import_time.monotonicTime)()
154
+ };
155
+ this._appendTraceEvent(event);
156
+ this._context.instrumentation.addListener(this, this._context);
157
+ this._eventListeners.push(
158
+ import_eventsHelper.eventsHelper.addEventListener(this._context, import_browserContext.BrowserContext.Events.Console, this._onConsoleMessage.bind(this)),
159
+ import_eventsHelper.eventsHelper.addEventListener(this._context, import_browserContext.BrowserContext.Events.PageError, this._onPageError.bind(this))
160
+ );
161
+ if (this._state.options.screenshots)
162
+ this._startScreencast();
163
+ if (this._state.options.snapshots)
164
+ await this._snapshotter?.start();
165
+ return { traceName: this._state.traceName };
166
+ }
167
+ _currentGroupId() {
168
+ return this._state?.groupStack.length ? this._state.groupStack[this._state.groupStack.length - 1] : void 0;
169
+ }
170
+ group(name, location, metadata) {
171
+ if (!this._state)
172
+ return;
173
+ const stackFrames = [];
174
+ const { file, line, column } = location ?? metadata.location ?? {};
175
+ if (file) {
176
+ stackFrames.push({
177
+ file,
178
+ line: line ?? 0,
179
+ column: column ?? 0
180
+ });
181
+ }
182
+ const event = {
183
+ type: "before",
184
+ callId: metadata.id,
185
+ startTime: metadata.startTime,
186
+ title: name,
187
+ class: "Tracing",
188
+ method: "tracingGroup",
189
+ params: {},
190
+ stepId: metadata.stepId,
191
+ stack: stackFrames
192
+ };
193
+ if (this._currentGroupId())
194
+ event.parentId = this._currentGroupId();
195
+ this._state.groupStack.push(event.callId);
196
+ this._appendTraceEvent(event);
197
+ }
198
+ groupEnd() {
199
+ if (!this._state)
200
+ return;
201
+ const callId = this._state.groupStack.pop();
202
+ if (!callId)
203
+ return;
204
+ const event = {
205
+ type: "after",
206
+ callId,
207
+ endTime: (0, import_time.monotonicTime)()
208
+ };
209
+ this._appendTraceEvent(event);
210
+ }
211
+ _startScreencast() {
212
+ if (!(this._context instanceof import_browserContext.BrowserContext))
213
+ return;
214
+ for (const page of this._context.pages())
215
+ this._startScreencastInPage(page);
216
+ this._screencastListeners.push(
217
+ import_eventsHelper.eventsHelper.addEventListener(this._context, import_browserContext.BrowserContext.Events.Page, this._startScreencastInPage.bind(this))
218
+ );
219
+ }
220
+ _stopScreencast() {
221
+ import_eventsHelper.eventsHelper.removeEventListeners(this._screencastListeners);
222
+ if (!(this._context instanceof import_browserContext.BrowserContext))
223
+ return;
224
+ for (const page of this._context.pages())
225
+ page.screencast.setOptions(null);
226
+ }
227
+ _allocateNewTraceFile(state) {
228
+ const suffix = state.chunkOrdinal ? `-chunk${state.chunkOrdinal}` : ``;
229
+ state.chunkOrdinal++;
230
+ state.traceFile = import_path.default.join(state.tracesDir, `${state.traceName}${suffix}.trace`);
231
+ }
232
+ _changeTraceName(state, name, preserveNetworkResources) {
233
+ state.traceName = name;
234
+ state.chunkOrdinal = 0;
235
+ this._allocateNewTraceFile(state);
236
+ const newNetworkFile = import_path.default.join(state.tracesDir, name + ".network");
237
+ if (preserveNetworkResources)
238
+ this._fs.copyFile(state.networkFile, newNetworkFile);
239
+ state.networkFile = newNetworkFile;
240
+ }
241
+ async stop(progress) {
242
+ if (!this._state)
243
+ return;
244
+ if (this._isStopping)
245
+ throw new Error(`Tracing is already stopping`);
246
+ if (this._state.recording)
247
+ throw new Error(`Must stop trace file before stopping tracing`);
248
+ this._closeAllGroups();
249
+ this._harTracer.stop();
250
+ this.flushHarEntries();
251
+ const promise = progress ? progress.race(this._fs.syncAndGetError()) : this._fs.syncAndGetError();
252
+ await promise.finally(() => {
253
+ this._state = void 0;
254
+ });
255
+ }
256
+ async deleteTmpTracesDir() {
257
+ if (this._tracesTmpDir)
258
+ await (0, import_fileUtils.removeFolders)([this._tracesTmpDir]);
259
+ }
260
+ _createTracesDirIfNeeded() {
261
+ if (this._precreatedTracesDir)
262
+ return this._precreatedTracesDir;
263
+ this._tracesTmpDir = import_fs.default.mkdtempSync(import_path.default.join(import_os.default.tmpdir(), "playwright-tracing-"));
264
+ return this._tracesTmpDir;
265
+ }
266
+ abort() {
267
+ this._snapshotter?.dispose();
268
+ this._harTracer.stop();
269
+ }
270
+ async flush() {
271
+ this.abort();
272
+ await this._fs.syncAndGetError();
273
+ }
274
+ _closeAllGroups() {
275
+ while (this._currentGroupId())
276
+ this.groupEnd();
277
+ }
278
+ async stopChunk(progress, params) {
279
+ if (this._isStopping)
280
+ throw new Error(`Tracing is already stopping`);
281
+ this._isStopping = true;
282
+ if (!this._state || !this._state.recording) {
283
+ this._isStopping = false;
284
+ if (params.mode !== "discard")
285
+ throw new Error(`Must start tracing before stopping`);
286
+ return {};
287
+ }
288
+ this._closeAllGroups();
289
+ this._context.instrumentation.removeListener(this);
290
+ import_eventsHelper.eventsHelper.removeEventListeners(this._eventListeners);
291
+ if (this._state.options.screenshots)
292
+ this._stopScreencast();
293
+ if (this._state.options.snapshots)
294
+ this._snapshotter?.stop();
295
+ this.flushHarEntries();
296
+ const newNetworkFile = import_path.default.join(this._state.tracesDir, this._state.traceName + `-pwnetcopy-${this._state.chunkOrdinal}.network`);
297
+ const entries = [];
298
+ entries.push({ name: "trace.trace", value: this._state.traceFile });
299
+ entries.push({ name: "trace.network", value: newNetworkFile });
300
+ for (const sha1 of /* @__PURE__ */ new Set([...this._state.traceSha1s, ...this._state.networkSha1s]))
301
+ entries.push({ name: import_path.default.join("resources", sha1), value: import_path.default.join(this._state.resourcesDir, sha1) });
302
+ this._state.traceSha1s = /* @__PURE__ */ new Set();
303
+ if (params.mode === "discard") {
304
+ this._isStopping = false;
305
+ this._state.recording = false;
306
+ return {};
307
+ }
308
+ this._fs.copyFile(this._state.networkFile, newNetworkFile);
309
+ const zipFileName = this._state.traceFile + ".zip";
310
+ if (params.mode === "archive")
311
+ this._fs.zip(entries, zipFileName);
312
+ const promise = progress ? progress.race(this._fs.syncAndGetError()) : this._fs.syncAndGetError();
313
+ const error = await promise.catch((e) => e);
314
+ this._isStopping = false;
315
+ if (this._state)
316
+ this._state.recording = false;
317
+ if (error) {
318
+ if (!(0, import_progress.isAbortError)(error) && this._context instanceof import_browserContext.BrowserContext && !this._context._browser.isConnected())
319
+ return {};
320
+ throw error;
321
+ }
322
+ if (params.mode === "entries")
323
+ return { entries };
324
+ const artifact = new import_artifact.Artifact(this._context, zipFileName);
325
+ artifact.reportFinished();
326
+ return { artifact };
327
+ }
328
+ async _captureSnapshot(snapshotName, sdkObject, metadata) {
329
+ if (!snapshotName || !sdkObject.attribution.page)
330
+ return;
331
+ await this._snapshotter?.captureSnapshot(sdkObject.attribution.page, metadata.id, snapshotName).catch(() => {
332
+ });
333
+ }
334
+ _shouldCaptureSnapshot(sdkObject, metadata) {
335
+ return !!this._snapshotter?.started() && shouldCaptureSnapshot(metadata) && !!sdkObject.attribution.page;
336
+ }
337
+ onBeforeCall(sdkObject, metadata, parentId) {
338
+ const event = createBeforeActionTraceEvent(metadata, parentId ?? this._currentGroupId());
339
+ if (!event)
340
+ return Promise.resolve();
341
+ sdkObject.attribution.page?.screencast.temporarilyDisableThrottling();
342
+ if (this._shouldCaptureSnapshot(sdkObject, metadata))
343
+ event.beforeSnapshot = `before@${metadata.id}`;
344
+ this._state?.callIds.add(metadata.id);
345
+ this._appendTraceEvent(event);
346
+ return this._captureSnapshot(event.beforeSnapshot, sdkObject, metadata);
347
+ }
348
+ onBeforeInputAction(sdkObject, metadata) {
349
+ if (!this._state?.callIds.has(metadata.id))
350
+ return Promise.resolve();
351
+ const event = createInputActionTraceEvent(metadata);
352
+ if (!event)
353
+ return Promise.resolve();
354
+ sdkObject.attribution.page?.screencast.temporarilyDisableThrottling();
355
+ if (this._shouldCaptureSnapshot(sdkObject, metadata))
356
+ event.inputSnapshot = `input@${metadata.id}`;
357
+ this._appendTraceEvent(event);
358
+ return this._captureSnapshot(event.inputSnapshot, sdkObject, metadata);
359
+ }
360
+ onCallLog(sdkObject, metadata, logName, message) {
361
+ if (!this._state?.callIds.has(metadata.id))
362
+ return;
363
+ if (metadata.internal)
364
+ return;
365
+ if (logName !== "api")
366
+ return;
367
+ const event = createActionLogTraceEvent(metadata, message);
368
+ if (event)
369
+ this._appendTraceEvent(event);
370
+ }
371
+ onAfterCall(sdkObject, metadata) {
372
+ if (!this._state?.callIds.has(metadata.id))
373
+ return Promise.resolve();
374
+ this._state?.callIds.delete(metadata.id);
375
+ const event = createAfterActionTraceEvent(metadata);
376
+ if (!event)
377
+ return Promise.resolve();
378
+ sdkObject.attribution.page?.screencast.temporarilyDisableThrottling();
379
+ if (this._shouldCaptureSnapshot(sdkObject, metadata))
380
+ event.afterSnapshot = `after@${metadata.id}`;
381
+ this._appendTraceEvent(event);
382
+ return this._captureSnapshot(event.afterSnapshot, sdkObject, metadata);
383
+ }
384
+ onEntryStarted(entry) {
385
+ this._pendingHarEntries.add(entry);
386
+ }
387
+ onEntryFinished(entry) {
388
+ this._pendingHarEntries.delete(entry);
389
+ const event = { type: "resource-snapshot", snapshot: entry };
390
+ const visited = visitTraceEvent(event, this._state.networkSha1s);
391
+ this._fs.appendFile(
392
+ this._state.networkFile,
393
+ JSON.stringify(visited) + "\n",
394
+ true
395
+ /* flush */
396
+ );
397
+ }
398
+ flushHarEntries() {
399
+ const harLines = [];
400
+ for (const entry of this._pendingHarEntries) {
401
+ const event = { type: "resource-snapshot", snapshot: entry };
402
+ const visited = visitTraceEvent(event, this._state.networkSha1s);
403
+ harLines.push(JSON.stringify(visited));
404
+ }
405
+ this._pendingHarEntries.clear();
406
+ if (harLines.length)
407
+ this._fs.appendFile(
408
+ this._state.networkFile,
409
+ harLines.join("\n") + "\n",
410
+ true
411
+ /* flush */
412
+ );
413
+ }
414
+ onContentBlob(sha1, buffer) {
415
+ this._appendResource(sha1, buffer);
416
+ }
417
+ onSnapshotterBlob(blob) {
418
+ this._appendResource(blob.sha1, blob.buffer);
419
+ }
420
+ onFrameSnapshot(snapshot) {
421
+ this._appendTraceEvent({ type: "frame-snapshot", snapshot });
422
+ }
423
+ _onConsoleMessage(message) {
424
+ const event = {
425
+ type: "console",
426
+ messageType: message.type(),
427
+ text: message.text(),
428
+ args: message.args().map((a) => ({ preview: a.toString(), value: a.rawValue() })),
429
+ location: message.location(),
430
+ time: (0, import_time.monotonicTime)(),
431
+ pageId: message.page()?.guid
432
+ };
433
+ this._appendTraceEvent(event);
434
+ }
435
+ onDialog(dialog) {
436
+ const event = {
437
+ type: "event",
438
+ time: (0, import_time.monotonicTime)(),
439
+ class: "BrowserContext",
440
+ method: "dialog",
441
+ params: { pageId: dialog.page().guid, type: dialog.type(), message: dialog.message(), defaultValue: dialog.defaultValue() }
442
+ };
443
+ this._appendTraceEvent(event);
444
+ }
445
+ onDownload(page, download) {
446
+ const event = {
447
+ type: "event",
448
+ time: (0, import_time.monotonicTime)(),
449
+ class: "BrowserContext",
450
+ method: "download",
451
+ params: { pageId: page.guid, url: download.url, suggestedFilename: download.suggestedFilename() }
452
+ };
453
+ this._appendTraceEvent(event);
454
+ }
455
+ onPageOpen(page) {
456
+ const event = {
457
+ type: "event",
458
+ time: (0, import_time.monotonicTime)(),
459
+ class: "BrowserContext",
460
+ method: "page",
461
+ params: { pageId: page.guid, openerPageId: page.opener()?.guid }
462
+ };
463
+ this._appendTraceEvent(event);
464
+ }
465
+ onPageClose(page) {
466
+ const event = {
467
+ type: "event",
468
+ time: (0, import_time.monotonicTime)(),
469
+ class: "BrowserContext",
470
+ method: "pageClosed",
471
+ params: { pageId: page.guid }
472
+ };
473
+ this._appendTraceEvent(event);
474
+ }
475
+ _onPageError(error, page) {
476
+ const event = {
477
+ type: "event",
478
+ time: (0, import_time.monotonicTime)(),
479
+ class: "BrowserContext",
480
+ method: "pageError",
481
+ params: { error: (0, import_errors.serializeError)(error) },
482
+ pageId: page.guid
483
+ };
484
+ this._appendTraceEvent(event);
485
+ }
486
+ _startScreencastInPage(page) {
487
+ page.screencast.setOptions(kScreencastOptions);
488
+ const prefix = page.guid;
489
+ this._screencastListeners.push(
490
+ import_eventsHelper.eventsHelper.addEventListener(page, import_page.Page.Events.ScreencastFrame, (params) => {
491
+ const suffix = params.timestamp || Date.now();
492
+ const sha1 = `${prefix}-${suffix}.jpeg`;
493
+ const event = {
494
+ type: "screencast-frame",
495
+ pageId: page.guid,
496
+ sha1,
497
+ width: params.width,
498
+ height: params.height,
499
+ timestamp: (0, import_time.monotonicTime)(),
500
+ frameSwapWallTime: params.frameSwapWallTime
501
+ };
502
+ this._appendResource(sha1, params.buffer);
503
+ this._appendTraceEvent(event);
504
+ })
505
+ );
506
+ }
507
+ _appendTraceEvent(event) {
508
+ const visited = visitTraceEvent(event, this._state.traceSha1s);
509
+ const flush = this._state.options.live || event.type !== "event" && event.type !== "console" && event.type !== "log";
510
+ this._fs.appendFile(this._state.traceFile, JSON.stringify(visited) + "\n", flush);
511
+ }
512
+ _appendResource(sha1, buffer) {
513
+ if (this._allResources.has(sha1))
514
+ return;
515
+ this._allResources.add(sha1);
516
+ const resourcePath = import_path.default.join(this._state.resourcesDir, sha1);
517
+ this._fs.writeFile(
518
+ resourcePath,
519
+ buffer,
520
+ true
521
+ /* skipIfExists */
522
+ );
523
+ }
524
+ }
525
+ function visitTraceEvent(object, sha1s) {
526
+ if (Array.isArray(object))
527
+ return object.map((o) => visitTraceEvent(o, sha1s));
528
+ if (object instanceof import_dispatcher.Dispatcher)
529
+ return `<${object._type}>`;
530
+ if (object instanceof Buffer)
531
+ return `<Buffer>`;
532
+ if (object instanceof Date)
533
+ return object;
534
+ if (typeof object === "object") {
535
+ const result = {};
536
+ for (const key in object) {
537
+ if (key === "sha1" || key === "_sha1" || key.endsWith("Sha1")) {
538
+ const sha1 = object[key];
539
+ if (sha1)
540
+ sha1s.add(sha1);
541
+ }
542
+ result[key] = visitTraceEvent(object[key], sha1s);
543
+ }
544
+ return result;
545
+ }
546
+ return object;
547
+ }
548
+ function shouldCaptureSnapshot(metadata) {
549
+ const metainfo = import_protocolMetainfo.methodMetainfo.get(metadata.type + "." + metadata.method);
550
+ return !!metainfo?.snapshot;
551
+ }
552
+ function createBeforeActionTraceEvent(metadata, parentId) {
553
+ if (metadata.internal || metadata.method.startsWith("tracing"))
554
+ return null;
555
+ const event = {
556
+ type: "before",
557
+ callId: metadata.id,
558
+ startTime: metadata.startTime,
559
+ title: metadata.title,
560
+ class: metadata.type,
561
+ method: metadata.method,
562
+ params: metadata.params,
563
+ stepId: metadata.stepId,
564
+ pageId: metadata.pageId
565
+ };
566
+ if (parentId)
567
+ event.parentId = parentId;
568
+ return event;
569
+ }
570
+ function createInputActionTraceEvent(metadata) {
571
+ if (metadata.internal || metadata.method.startsWith("tracing"))
572
+ return null;
573
+ return {
574
+ type: "input",
575
+ callId: metadata.id,
576
+ point: metadata.point
577
+ };
578
+ }
579
+ function createActionLogTraceEvent(metadata, message) {
580
+ if (metadata.internal || metadata.method.startsWith("tracing"))
581
+ return null;
582
+ return {
583
+ type: "log",
584
+ callId: metadata.id,
585
+ time: (0, import_time.monotonicTime)(),
586
+ message
587
+ };
588
+ }
589
+ function createAfterActionTraceEvent(metadata) {
590
+ if (metadata.internal || metadata.method.startsWith("tracing"))
591
+ return null;
592
+ return {
593
+ type: "after",
594
+ callId: metadata.id,
595
+ endTime: metadata.endTime,
596
+ error: metadata.error?.error,
597
+ result: metadata.result,
598
+ point: metadata.point
599
+ };
600
+ }
601
+ // Annotate the CommonJS export names for ESM import in node:
602
+ 0 && (module.exports = {
603
+ Tracing
604
+ });