@pedropaulovc/playwright-core 1.59.0-next

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (366) hide show
  1. package/README.md +3 -0
  2. package/ThirdPartyNotices.txt +4076 -0
  3. package/bin/install_media_pack.ps1 +5 -0
  4. package/bin/install_webkit_wsl.ps1 +33 -0
  5. package/bin/reinstall_chrome_beta_linux.sh +42 -0
  6. package/bin/reinstall_chrome_beta_mac.sh +13 -0
  7. package/bin/reinstall_chrome_beta_win.ps1 +24 -0
  8. package/bin/reinstall_chrome_stable_linux.sh +42 -0
  9. package/bin/reinstall_chrome_stable_mac.sh +12 -0
  10. package/bin/reinstall_chrome_stable_win.ps1 +24 -0
  11. package/bin/reinstall_msedge_beta_linux.sh +48 -0
  12. package/bin/reinstall_msedge_beta_mac.sh +11 -0
  13. package/bin/reinstall_msedge_beta_win.ps1 +23 -0
  14. package/bin/reinstall_msedge_dev_linux.sh +48 -0
  15. package/bin/reinstall_msedge_dev_mac.sh +11 -0
  16. package/bin/reinstall_msedge_dev_win.ps1 +23 -0
  17. package/bin/reinstall_msedge_stable_linux.sh +48 -0
  18. package/bin/reinstall_msedge_stable_mac.sh +11 -0
  19. package/bin/reinstall_msedge_stable_win.ps1 +24 -0
  20. package/browsers.json +79 -0
  21. package/cli.js +18 -0
  22. package/index.d.ts +17 -0
  23. package/index.js +32 -0
  24. package/index.mjs +28 -0
  25. package/lib/androidServerImpl.js +65 -0
  26. package/lib/browserServerImpl.js +120 -0
  27. package/lib/cli/driver.js +97 -0
  28. package/lib/cli/program.js +603 -0
  29. package/lib/cli/programWithTestStub.js +74 -0
  30. package/lib/client/android.js +361 -0
  31. package/lib/client/api.js +137 -0
  32. package/lib/client/artifact.js +79 -0
  33. package/lib/client/browser.js +161 -0
  34. package/lib/client/browserContext.js +582 -0
  35. package/lib/client/browserType.js +185 -0
  36. package/lib/client/cdpSession.js +51 -0
  37. package/lib/client/channelOwner.js +194 -0
  38. package/lib/client/clientHelper.js +64 -0
  39. package/lib/client/clientInstrumentation.js +55 -0
  40. package/lib/client/clientStackTrace.js +69 -0
  41. package/lib/client/clock.js +68 -0
  42. package/lib/client/connection.js +318 -0
  43. package/lib/client/consoleMessage.js +58 -0
  44. package/lib/client/coverage.js +44 -0
  45. package/lib/client/dialog.js +56 -0
  46. package/lib/client/download.js +62 -0
  47. package/lib/client/electron.js +138 -0
  48. package/lib/client/elementHandle.js +284 -0
  49. package/lib/client/errors.js +77 -0
  50. package/lib/client/eventEmitter.js +314 -0
  51. package/lib/client/events.js +103 -0
  52. package/lib/client/fetch.js +368 -0
  53. package/lib/client/fileChooser.js +46 -0
  54. package/lib/client/fileUtils.js +34 -0
  55. package/lib/client/frame.js +409 -0
  56. package/lib/client/harRouter.js +87 -0
  57. package/lib/client/input.js +84 -0
  58. package/lib/client/jsHandle.js +109 -0
  59. package/lib/client/jsonPipe.js +39 -0
  60. package/lib/client/localUtils.js +60 -0
  61. package/lib/client/locator.js +369 -0
  62. package/lib/client/network.js +747 -0
  63. package/lib/client/page.js +745 -0
  64. package/lib/client/pageAgent.js +64 -0
  65. package/lib/client/platform.js +77 -0
  66. package/lib/client/playwright.js +71 -0
  67. package/lib/client/selectors.js +55 -0
  68. package/lib/client/stream.js +39 -0
  69. package/lib/client/timeoutSettings.js +79 -0
  70. package/lib/client/tracing.js +119 -0
  71. package/lib/client/types.js +28 -0
  72. package/lib/client/video.js +59 -0
  73. package/lib/client/waiter.js +142 -0
  74. package/lib/client/webError.js +39 -0
  75. package/lib/client/webSocket.js +93 -0
  76. package/lib/client/worker.js +85 -0
  77. package/lib/client/writableStream.js +39 -0
  78. package/lib/generated/bindingsControllerSource.js +28 -0
  79. package/lib/generated/clockSource.js +28 -0
  80. package/lib/generated/injectedScriptSource.js +28 -0
  81. package/lib/generated/pollingRecorderSource.js +28 -0
  82. package/lib/generated/storageScriptSource.js +28 -0
  83. package/lib/generated/utilityScriptSource.js +28 -0
  84. package/lib/generated/webSocketMockSource.js +336 -0
  85. package/lib/inProcessFactory.js +60 -0
  86. package/lib/inprocess.js +3 -0
  87. package/lib/mcpBundle.js +84 -0
  88. package/lib/mcpBundleImpl/index.js +147 -0
  89. package/lib/outofprocess.js +76 -0
  90. package/lib/protocol/serializers.js +197 -0
  91. package/lib/protocol/validator.js +2969 -0
  92. package/lib/protocol/validatorPrimitives.js +193 -0
  93. package/lib/remote/playwrightConnection.js +129 -0
  94. package/lib/remote/playwrightServer.js +334 -0
  95. package/lib/server/agent/actionRunner.js +335 -0
  96. package/lib/server/agent/actions.js +128 -0
  97. package/lib/server/agent/codegen.js +111 -0
  98. package/lib/server/agent/context.js +150 -0
  99. package/lib/server/agent/expectTools.js +156 -0
  100. package/lib/server/agent/pageAgent.js +204 -0
  101. package/lib/server/agent/performTools.js +262 -0
  102. package/lib/server/agent/tool.js +109 -0
  103. package/lib/server/android/android.js +465 -0
  104. package/lib/server/android/backendAdb.js +177 -0
  105. package/lib/server/artifact.js +127 -0
  106. package/lib/server/bidi/bidiBrowser.js +549 -0
  107. package/lib/server/bidi/bidiChromium.js +148 -0
  108. package/lib/server/bidi/bidiConnection.js +213 -0
  109. package/lib/server/bidi/bidiDeserializer.js +116 -0
  110. package/lib/server/bidi/bidiExecutionContext.js +267 -0
  111. package/lib/server/bidi/bidiFirefox.js +128 -0
  112. package/lib/server/bidi/bidiInput.js +146 -0
  113. package/lib/server/bidi/bidiNetworkManager.js +383 -0
  114. package/lib/server/bidi/bidiOverCdp.js +102 -0
  115. package/lib/server/bidi/bidiPage.js +583 -0
  116. package/lib/server/bidi/bidiPdf.js +106 -0
  117. package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
  118. package/lib/server/bidi/third_party/bidiKeyboard.js +256 -0
  119. package/lib/server/bidi/third_party/bidiProtocol.js +24 -0
  120. package/lib/server/bidi/third_party/bidiProtocolCore.js +180 -0
  121. package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -0
  122. package/lib/server/bidi/third_party/bidiSerializer.js +148 -0
  123. package/lib/server/bidi/third_party/firefoxPrefs.js +259 -0
  124. package/lib/server/browser.js +149 -0
  125. package/lib/server/browserContext.js +702 -0
  126. package/lib/server/browserType.js +336 -0
  127. package/lib/server/callLog.js +82 -0
  128. package/lib/server/chromium/appIcon.png +0 -0
  129. package/lib/server/chromium/chromium.js +395 -0
  130. package/lib/server/chromium/chromiumSwitches.js +104 -0
  131. package/lib/server/chromium/crBrowser.js +511 -0
  132. package/lib/server/chromium/crConnection.js +197 -0
  133. package/lib/server/chromium/crCoverage.js +235 -0
  134. package/lib/server/chromium/crDevTools.js +111 -0
  135. package/lib/server/chromium/crDragDrop.js +131 -0
  136. package/lib/server/chromium/crExecutionContext.js +146 -0
  137. package/lib/server/chromium/crInput.js +187 -0
  138. package/lib/server/chromium/crNetworkManager.js +707 -0
  139. package/lib/server/chromium/crPage.js +1001 -0
  140. package/lib/server/chromium/crPdf.js +121 -0
  141. package/lib/server/chromium/crProtocolHelper.js +145 -0
  142. package/lib/server/chromium/crServiceWorker.js +136 -0
  143. package/lib/server/chromium/defaultFontFamilies.js +162 -0
  144. package/lib/server/chromium/protocol.d.js +16 -0
  145. package/lib/server/clock.js +149 -0
  146. package/lib/server/codegen/csharp.js +327 -0
  147. package/lib/server/codegen/java.js +274 -0
  148. package/lib/server/codegen/javascript.js +247 -0
  149. package/lib/server/codegen/jsonl.js +52 -0
  150. package/lib/server/codegen/language.js +132 -0
  151. package/lib/server/codegen/languages.js +68 -0
  152. package/lib/server/codegen/python.js +279 -0
  153. package/lib/server/codegen/types.js +16 -0
  154. package/lib/server/console.js +57 -0
  155. package/lib/server/cookieStore.js +206 -0
  156. package/lib/server/debugController.js +191 -0
  157. package/lib/server/debugger.js +119 -0
  158. package/lib/server/deviceDescriptors.js +39 -0
  159. package/lib/server/deviceDescriptorsSource.json +1779 -0
  160. package/lib/server/dialog.js +116 -0
  161. package/lib/server/dispatchers/androidDispatcher.js +325 -0
  162. package/lib/server/dispatchers/artifactDispatcher.js +118 -0
  163. package/lib/server/dispatchers/browserContextDispatcher.js +384 -0
  164. package/lib/server/dispatchers/browserDispatcher.js +118 -0
  165. package/lib/server/dispatchers/browserTypeDispatcher.js +64 -0
  166. package/lib/server/dispatchers/cdpSessionDispatcher.js +44 -0
  167. package/lib/server/dispatchers/debugControllerDispatcher.js +78 -0
  168. package/lib/server/dispatchers/dialogDispatcher.js +47 -0
  169. package/lib/server/dispatchers/dispatcher.js +364 -0
  170. package/lib/server/dispatchers/electronDispatcher.js +89 -0
  171. package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -0
  172. package/lib/server/dispatchers/frameDispatcher.js +227 -0
  173. package/lib/server/dispatchers/jsHandleDispatcher.js +85 -0
  174. package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -0
  175. package/lib/server/dispatchers/localUtilsDispatcher.js +149 -0
  176. package/lib/server/dispatchers/networkDispatchers.js +213 -0
  177. package/lib/server/dispatchers/pageAgentDispatcher.js +96 -0
  178. package/lib/server/dispatchers/pageDispatcher.js +393 -0
  179. package/lib/server/dispatchers/playwrightDispatcher.js +108 -0
  180. package/lib/server/dispatchers/streamDispatcher.js +67 -0
  181. package/lib/server/dispatchers/tracingDispatcher.js +68 -0
  182. package/lib/server/dispatchers/webSocketRouteDispatcher.js +165 -0
  183. package/lib/server/dispatchers/writableStreamDispatcher.js +79 -0
  184. package/lib/server/dom.js +815 -0
  185. package/lib/server/download.js +70 -0
  186. package/lib/server/electron/electron.js +273 -0
  187. package/lib/server/electron/loader.js +29 -0
  188. package/lib/server/errors.js +69 -0
  189. package/lib/server/fetch.js +621 -0
  190. package/lib/server/fileChooser.js +43 -0
  191. package/lib/server/fileUploadUtils.js +84 -0
  192. package/lib/server/firefox/ffBrowser.js +418 -0
  193. package/lib/server/firefox/ffConnection.js +142 -0
  194. package/lib/server/firefox/ffExecutionContext.js +150 -0
  195. package/lib/server/firefox/ffInput.js +159 -0
  196. package/lib/server/firefox/ffNetworkManager.js +256 -0
  197. package/lib/server/firefox/ffPage.js +497 -0
  198. package/lib/server/firefox/firefox.js +114 -0
  199. package/lib/server/firefox/protocol.d.js +16 -0
  200. package/lib/server/formData.js +147 -0
  201. package/lib/server/frameSelectors.js +160 -0
  202. package/lib/server/frames.js +1471 -0
  203. package/lib/server/har/harRecorder.js +147 -0
  204. package/lib/server/har/harTracer.js +607 -0
  205. package/lib/server/harBackend.js +157 -0
  206. package/lib/server/helper.js +96 -0
  207. package/lib/server/index.js +58 -0
  208. package/lib/server/input.js +277 -0
  209. package/lib/server/instrumentation.js +72 -0
  210. package/lib/server/javascript.js +291 -0
  211. package/lib/server/launchApp.js +128 -0
  212. package/lib/server/localUtils.js +214 -0
  213. package/lib/server/macEditingCommands.js +143 -0
  214. package/lib/server/network.js +667 -0
  215. package/lib/server/page.js +830 -0
  216. package/lib/server/pipeTransport.js +89 -0
  217. package/lib/server/playwright.js +69 -0
  218. package/lib/server/progress.js +132 -0
  219. package/lib/server/protocolError.js +52 -0
  220. package/lib/server/recorder/chat.js +161 -0
  221. package/lib/server/recorder/recorderApp.js +366 -0
  222. package/lib/server/recorder/recorderRunner.js +138 -0
  223. package/lib/server/recorder/recorderSignalProcessor.js +83 -0
  224. package/lib/server/recorder/recorderUtils.js +157 -0
  225. package/lib/server/recorder/throttledFile.js +57 -0
  226. package/lib/server/recorder.js +499 -0
  227. package/lib/server/registry/browserFetcher.js +177 -0
  228. package/lib/server/registry/dependencies.js +371 -0
  229. package/lib/server/registry/index.js +1422 -0
  230. package/lib/server/registry/nativeDeps.js +1280 -0
  231. package/lib/server/registry/oopDownloadBrowserMain.js +127 -0
  232. package/lib/server/screencast.js +190 -0
  233. package/lib/server/screenshotter.js +333 -0
  234. package/lib/server/selectors.js +112 -0
  235. package/lib/server/socksClientCertificatesInterceptor.js +383 -0
  236. package/lib/server/socksInterceptor.js +95 -0
  237. package/lib/server/trace/recorder/snapshotter.js +147 -0
  238. package/lib/server/trace/recorder/snapshotterInjected.js +561 -0
  239. package/lib/server/trace/recorder/tracing.js +604 -0
  240. package/lib/server/trace/viewer/traceExporter.js +679 -0
  241. package/lib/server/trace/viewer/traceParser.js +72 -0
  242. package/lib/server/trace/viewer/traceViewer.js +245 -0
  243. package/lib/server/transport.js +181 -0
  244. package/lib/server/types.js +28 -0
  245. package/lib/server/usKeyboardLayout.js +145 -0
  246. package/lib/server/utils/ascii.js +44 -0
  247. package/lib/server/utils/comparators.js +139 -0
  248. package/lib/server/utils/crypto.js +216 -0
  249. package/lib/server/utils/debug.js +42 -0
  250. package/lib/server/utils/debugLogger.js +122 -0
  251. package/lib/server/utils/env.js +73 -0
  252. package/lib/server/utils/eventsHelper.js +39 -0
  253. package/lib/server/utils/expectUtils.js +123 -0
  254. package/lib/server/utils/fileUtils.js +191 -0
  255. package/lib/server/utils/happyEyeballs.js +207 -0
  256. package/lib/server/utils/hostPlatform.js +123 -0
  257. package/lib/server/utils/httpServer.js +203 -0
  258. package/lib/server/utils/imageUtils.js +141 -0
  259. package/lib/server/utils/image_tools/colorUtils.js +89 -0
  260. package/lib/server/utils/image_tools/compare.js +109 -0
  261. package/lib/server/utils/image_tools/imageChannel.js +78 -0
  262. package/lib/server/utils/image_tools/stats.js +102 -0
  263. package/lib/server/utils/linuxUtils.js +71 -0
  264. package/lib/server/utils/network.js +242 -0
  265. package/lib/server/utils/nodePlatform.js +154 -0
  266. package/lib/server/utils/pipeTransport.js +84 -0
  267. package/lib/server/utils/processLauncher.js +241 -0
  268. package/lib/server/utils/profiler.js +65 -0
  269. package/lib/server/utils/socksProxy.js +511 -0
  270. package/lib/server/utils/spawnAsync.js +41 -0
  271. package/lib/server/utils/task.js +51 -0
  272. package/lib/server/utils/userAgent.js +98 -0
  273. package/lib/server/utils/wsServer.js +121 -0
  274. package/lib/server/utils/zipFile.js +74 -0
  275. package/lib/server/utils/zones.js +57 -0
  276. package/lib/server/videoRecorder.js +124 -0
  277. package/lib/server/webkit/protocol.d.js +16 -0
  278. package/lib/server/webkit/webkit.js +108 -0
  279. package/lib/server/webkit/wkBrowser.js +335 -0
  280. package/lib/server/webkit/wkConnection.js +144 -0
  281. package/lib/server/webkit/wkExecutionContext.js +154 -0
  282. package/lib/server/webkit/wkInput.js +181 -0
  283. package/lib/server/webkit/wkInterceptableRequest.js +197 -0
  284. package/lib/server/webkit/wkPage.js +1158 -0
  285. package/lib/server/webkit/wkProvisionalPage.js +83 -0
  286. package/lib/server/webkit/wkWorkers.js +105 -0
  287. package/lib/third_party/pixelmatch.js +255 -0
  288. package/lib/utils/isomorphic/ariaSnapshot.js +455 -0
  289. package/lib/utils/isomorphic/assert.js +31 -0
  290. package/lib/utils/isomorphic/colors.js +72 -0
  291. package/lib/utils/isomorphic/cssParser.js +245 -0
  292. package/lib/utils/isomorphic/cssTokenizer.js +1051 -0
  293. package/lib/utils/isomorphic/headers.js +53 -0
  294. package/lib/utils/isomorphic/locatorGenerators.js +689 -0
  295. package/lib/utils/isomorphic/locatorParser.js +176 -0
  296. package/lib/utils/isomorphic/locatorUtils.js +81 -0
  297. package/lib/utils/isomorphic/lruCache.js +51 -0
  298. package/lib/utils/isomorphic/manualPromise.js +114 -0
  299. package/lib/utils/isomorphic/mimeType.js +459 -0
  300. package/lib/utils/isomorphic/multimap.js +80 -0
  301. package/lib/utils/isomorphic/protocolFormatter.js +81 -0
  302. package/lib/utils/isomorphic/protocolMetainfo.js +330 -0
  303. package/lib/utils/isomorphic/rtti.js +43 -0
  304. package/lib/utils/isomorphic/selectorParser.js +386 -0
  305. package/lib/utils/isomorphic/semaphore.js +54 -0
  306. package/lib/utils/isomorphic/stackTrace.js +158 -0
  307. package/lib/utils/isomorphic/stringUtils.js +204 -0
  308. package/lib/utils/isomorphic/time.js +49 -0
  309. package/lib/utils/isomorphic/timeoutRunner.js +66 -0
  310. package/lib/utils/isomorphic/trace/entries.js +16 -0
  311. package/lib/utils/isomorphic/trace/snapshotRenderer.js +499 -0
  312. package/lib/utils/isomorphic/trace/snapshotServer.js +120 -0
  313. package/lib/utils/isomorphic/trace/snapshotStorage.js +89 -0
  314. package/lib/utils/isomorphic/trace/traceLoader.js +131 -0
  315. package/lib/utils/isomorphic/trace/traceModel.js +365 -0
  316. package/lib/utils/isomorphic/trace/traceModernizer.js +400 -0
  317. package/lib/utils/isomorphic/trace/versions/traceV3.js +16 -0
  318. package/lib/utils/isomorphic/trace/versions/traceV4.js +16 -0
  319. package/lib/utils/isomorphic/trace/versions/traceV5.js +16 -0
  320. package/lib/utils/isomorphic/trace/versions/traceV6.js +16 -0
  321. package/lib/utils/isomorphic/trace/versions/traceV7.js +16 -0
  322. package/lib/utils/isomorphic/trace/versions/traceV8.js +16 -0
  323. package/lib/utils/isomorphic/traceUtils.js +58 -0
  324. package/lib/utils/isomorphic/types.js +16 -0
  325. package/lib/utils/isomorphic/urlMatch.js +190 -0
  326. package/lib/utils/isomorphic/utilityScriptSerializers.js +251 -0
  327. package/lib/utils/isomorphic/yaml.js +84 -0
  328. package/lib/utils.js +111 -0
  329. package/lib/utilsBundle.js +109 -0
  330. package/lib/utilsBundleImpl/index.js +218 -0
  331. package/lib/utilsBundleImpl/xdg-open +1066 -0
  332. package/lib/vite/htmlReport/index.html +84 -0
  333. package/lib/vite/recorder/assets/codeMirrorModule-DYBRYzYX.css +1 -0
  334. package/lib/vite/recorder/assets/codeMirrorModule-DadYNm1I.js +32 -0
  335. package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  336. package/lib/vite/recorder/assets/index-BSjZa4pk.css +1 -0
  337. package/lib/vite/recorder/assets/index-BhTWtUlo.js +193 -0
  338. package/lib/vite/recorder/index.html +29 -0
  339. package/lib/vite/recorder/playwright-logo.svg +9 -0
  340. package/lib/vite/traceViewer/assets/codeMirrorModule-DwzBH9eL.js +32 -0
  341. package/lib/vite/traceViewer/assets/codeMirrorModule-a5XoALAZ.js +32 -0
  342. package/lib/vite/traceViewer/assets/defaultSettingsView-CJSZINFr.js +266 -0
  343. package/lib/vite/traceViewer/assets/defaultSettingsView-CdCX8877.js +266 -0
  344. package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
  345. package/lib/vite/traceViewer/codeMirrorModule.DYBRYzYX.css +1 -0
  346. package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  347. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +1 -0
  348. package/lib/vite/traceViewer/index.BVu7tZDe.css +1 -0
  349. package/lib/vite/traceViewer/index.Dd9jebqr.js +2 -0
  350. package/lib/vite/traceViewer/index.f4OcrOqs.js +2 -0
  351. package/lib/vite/traceViewer/index.html +43 -0
  352. package/lib/vite/traceViewer/manifest.webmanifest +16 -0
  353. package/lib/vite/traceViewer/playwright-logo.svg +9 -0
  354. package/lib/vite/traceViewer/snapshot.html +21 -0
  355. package/lib/vite/traceViewer/sw.bundle.js +5 -0
  356. package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
  357. package/lib/vite/traceViewer/uiMode.CQJ9SCIQ.js +5 -0
  358. package/lib/vite/traceViewer/uiMode.html +17 -0
  359. package/lib/vite/traceViewer/uiMode.qcahlSup.js +5 -0
  360. package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -0
  361. package/lib/zipBundle.js +34 -0
  362. package/lib/zipBundleImpl.js +5 -0
  363. package/package.json +43 -0
  364. package/types/protocol.d.ts +23824 -0
  365. package/types/structs.d.ts +45 -0
  366. package/types/types.d.ts +22843 -0
@@ -0,0 +1,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
+ });