@smoothdeploy/playwright-core 1.58.4 → 1.60.0-beta-1780662356000

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 (380) hide show
  1. package/ThirdPartyNotices.txt +7 -4070
  2. package/browsers.json +16 -14
  3. package/cli.js +4 -1
  4. package/index.js +1 -1
  5. package/lib/bootstrap.js +77 -0
  6. package/lib/coreBundle.js +70057 -0
  7. package/lib/entry/cliDaemon.js +5 -0
  8. package/lib/entry/dashboardApp.js +3 -0
  9. package/lib/entry/mcp.js +10 -0
  10. package/lib/entry/oopBrowserDownload.js +3 -0
  11. package/lib/{server/deviceDescriptors.js → package.js} +18 -7
  12. package/lib/server/deviceDescriptorsSource.json +137 -137
  13. package/lib/server/electron/loader.js +99 -13
  14. package/lib/serverRegistry.js +7343 -0
  15. package/lib/serverRegistry.js.LICENSE +354 -0
  16. package/lib/tools/cli-client/channelSessions.js +141 -0
  17. package/lib/tools/cli-client/cli.js +6 -0
  18. package/lib/tools/cli-client/help.json +679 -0
  19. package/lib/tools/cli-client/minimist.js +128 -0
  20. package/lib/tools/cli-client/output.js +343 -0
  21. package/lib/tools/cli-client/program.js +380 -0
  22. package/lib/tools/cli-client/registry.js +176 -0
  23. package/lib/tools/cli-client/session.js +265 -0
  24. package/lib/tools/cli-client/skill/SKILL.md +388 -0
  25. package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
  26. package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
  27. package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
  28. package/lib/tools/cli-client/skill/references/running-code.md +241 -0
  29. package/lib/tools/cli-client/skill/references/session-management.md +225 -0
  30. package/lib/tools/cli-client/skill/references/spec-driven-testing.md +305 -0
  31. package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
  32. package/lib/tools/cli-client/skill/references/test-generation.md +134 -0
  33. package/lib/tools/cli-client/skill/references/tracing.md +139 -0
  34. package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
  35. package/lib/tools/dashboard/appIcon.png +0 -0
  36. package/lib/tools/trace/SKILL.md +171 -0
  37. package/lib/{server/utils/profiler.js → tools/utils/extension.js} +42 -29
  38. package/lib/tools/utils/socketConnection.js +108 -0
  39. package/lib/utilsBundle.js +85377 -68
  40. package/lib/utilsBundle.js.LICENSE +2002 -0
  41. package/lib/vite/dashboard/assets/codicon-DCmgc-ay.ttf +0 -0
  42. package/lib/vite/dashboard/assets/firefox-1bWoP6pv.svg +1 -0
  43. package/lib/vite/dashboard/assets/firefox-beta-k3eOH_eK.svg +1 -0
  44. package/lib/vite/dashboard/assets/firefox-nightly-Cp5nfeDT.svg +1 -0
  45. package/lib/vite/dashboard/assets/index-BY2S1tHT.css +1 -0
  46. package/lib/vite/dashboard/assets/index-DpEq2p62.js +52 -0
  47. package/lib/vite/dashboard/assets/safari-na3_-uQk.svg +1 -0
  48. package/lib/vite/dashboard/index.html +29 -0
  49. package/lib/vite/dashboard/playwright-logo.svg +24 -0
  50. package/lib/vite/htmlReport/index.html +2 -70
  51. package/lib/vite/htmlReport/report.css +1 -0
  52. package/lib/vite/htmlReport/report.js +72 -0
  53. package/lib/vite/recorder/assets/{codeMirrorModule-SGmxtuwi.js → codeMirrorModule-DyIpd_mA.js} +20 -20
  54. package/lib/vite/recorder/assets/index-4ZiSSCmn.css +1 -0
  55. package/lib/vite/recorder/assets/index-5q9Mg4LR.js +195 -0
  56. package/lib/vite/recorder/index.html +2 -2
  57. package/lib/vite/traceViewer/assets/{codeMirrorModule-BOUrQdmH.js → codeMirrorModule-DZq9EItR.js} +20 -20
  58. package/lib/vite/traceViewer/assets/defaultSettingsView-D4EpQvB-.js +262 -0
  59. package/lib/vite/traceViewer/assets/urlMatch-BYQrIQwR.js +1 -0
  60. package/lib/vite/traceViewer/defaultSettingsView.BDKsFU3c.css +1 -0
  61. package/lib/vite/traceViewer/index.CcoKXsOB.js +2 -0
  62. package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
  63. package/lib/vite/traceViewer/index.html +5 -4
  64. package/lib/vite/traceViewer/snapshot.html +4 -15
  65. package/lib/vite/traceViewer/snapshot.v8KI4P3m.js +2 -0
  66. package/lib/vite/traceViewer/sw.bundle.js +4 -4
  67. package/lib/vite/traceViewer/uiMode.B1W9rAxj.js +6 -0
  68. package/lib/vite/traceViewer/uiMode.html +4 -3
  69. package/package.json +4 -14
  70. package/types/protocol.d.ts +1084 -343
  71. package/types/types.d.ts +6035 -4360
  72. package/lib/androidServerImpl.js +0 -65
  73. package/lib/browserServerImpl.js +0 -120
  74. package/lib/cli/driver.js +0 -97
  75. package/lib/cli/program.js +0 -589
  76. package/lib/cli/programWithTestStub.js +0 -74
  77. package/lib/client/android.js +0 -361
  78. package/lib/client/api.js +0 -137
  79. package/lib/client/artifact.js +0 -79
  80. package/lib/client/browser.js +0 -161
  81. package/lib/client/browserContext.js +0 -582
  82. package/lib/client/browserType.js +0 -185
  83. package/lib/client/cdpSession.js +0 -51
  84. package/lib/client/channelOwner.js +0 -195
  85. package/lib/client/clientHelper.js +0 -64
  86. package/lib/client/clientInstrumentation.js +0 -65
  87. package/lib/client/clientStackTrace.js +0 -69
  88. package/lib/client/clock.js +0 -68
  89. package/lib/client/connection.js +0 -318
  90. package/lib/client/consoleMessage.js +0 -58
  91. package/lib/client/coverage.js +0 -44
  92. package/lib/client/dialog.js +0 -56
  93. package/lib/client/download.js +0 -62
  94. package/lib/client/electron.js +0 -138
  95. package/lib/client/elementHandle.js +0 -284
  96. package/lib/client/errors.js +0 -77
  97. package/lib/client/eventEmitter.js +0 -314
  98. package/lib/client/events.js +0 -103
  99. package/lib/client/fetch.js +0 -368
  100. package/lib/client/fileChooser.js +0 -46
  101. package/lib/client/fileUtils.js +0 -34
  102. package/lib/client/frame.js +0 -409
  103. package/lib/client/harRouter.js +0 -87
  104. package/lib/client/input.js +0 -84
  105. package/lib/client/jsHandle.js +0 -109
  106. package/lib/client/jsonPipe.js +0 -39
  107. package/lib/client/localUtils.js +0 -60
  108. package/lib/client/locator.js +0 -369
  109. package/lib/client/network.js +0 -747
  110. package/lib/client/page.js +0 -745
  111. package/lib/client/pageAgent.js +0 -64
  112. package/lib/client/platform.js +0 -77
  113. package/lib/client/playwright.js +0 -71
  114. package/lib/client/selectors.js +0 -55
  115. package/lib/client/stream.js +0 -39
  116. package/lib/client/timeoutSettings.js +0 -79
  117. package/lib/client/tracing.js +0 -119
  118. package/lib/client/types.js +0 -28
  119. package/lib/client/video.js +0 -59
  120. package/lib/client/waiter.js +0 -142
  121. package/lib/client/webError.js +0 -39
  122. package/lib/client/webSocket.js +0 -93
  123. package/lib/client/worker.js +0 -85
  124. package/lib/client/writableStream.js +0 -39
  125. package/lib/generated/bindingsControllerSource.js +0 -28
  126. package/lib/generated/clockSource.js +0 -28
  127. package/lib/generated/injectedScriptSource.js +0 -28
  128. package/lib/generated/pollingRecorderSource.js +0 -28
  129. package/lib/generated/storageScriptSource.js +0 -28
  130. package/lib/generated/utilityScriptSource.js +0 -28
  131. package/lib/generated/webSocketMockSource.js +0 -336
  132. package/lib/inProcessFactory.js +0 -60
  133. package/lib/inprocess.js +0 -3
  134. package/lib/mcpBundle.js +0 -84
  135. package/lib/mcpBundleImpl/index.js +0 -147
  136. package/lib/outofprocess.js +0 -76
  137. package/lib/protocol/serializers.js +0 -197
  138. package/lib/protocol/validator.js +0 -3023
  139. package/lib/protocol/validatorPrimitives.js +0 -193
  140. package/lib/remote/playwrightConnection.js +0 -129
  141. package/lib/remote/playwrightServer.js +0 -334
  142. package/lib/server/agent/actionRunner.js +0 -335
  143. package/lib/server/agent/actions.js +0 -128
  144. package/lib/server/agent/codegen.js +0 -111
  145. package/lib/server/agent/context.js +0 -150
  146. package/lib/server/agent/expectTools.js +0 -156
  147. package/lib/server/agent/pageAgent.js +0 -204
  148. package/lib/server/agent/performTools.js +0 -262
  149. package/lib/server/agent/tool.js +0 -109
  150. package/lib/server/android/android.js +0 -465
  151. package/lib/server/android/backendAdb.js +0 -177
  152. package/lib/server/artifact.js +0 -127
  153. package/lib/server/bidi/bidiBrowser.js +0 -549
  154. package/lib/server/bidi/bidiChromium.js +0 -149
  155. package/lib/server/bidi/bidiConnection.js +0 -213
  156. package/lib/server/bidi/bidiDeserializer.js +0 -116
  157. package/lib/server/bidi/bidiExecutionContext.js +0 -267
  158. package/lib/server/bidi/bidiFirefox.js +0 -128
  159. package/lib/server/bidi/bidiInput.js +0 -146
  160. package/lib/server/bidi/bidiNetworkManager.js +0 -383
  161. package/lib/server/bidi/bidiOverCdp.js +0 -102
  162. package/lib/server/bidi/bidiPage.js +0 -583
  163. package/lib/server/bidi/bidiPdf.js +0 -106
  164. package/lib/server/bidi/third_party/bidiCommands.d.js +0 -22
  165. package/lib/server/bidi/third_party/bidiKeyboard.js +0 -256
  166. package/lib/server/bidi/third_party/bidiProtocol.js +0 -24
  167. package/lib/server/bidi/third_party/bidiProtocolCore.js +0 -180
  168. package/lib/server/bidi/third_party/bidiProtocolPermissions.js +0 -42
  169. package/lib/server/bidi/third_party/bidiSerializer.js +0 -148
  170. package/lib/server/bidi/third_party/firefoxPrefs.js +0 -259
  171. package/lib/server/browser.js +0 -149
  172. package/lib/server/browserContext.js +0 -700
  173. package/lib/server/browserType.js +0 -336
  174. package/lib/server/callLog.js +0 -82
  175. package/lib/server/chromium/chromium.js +0 -397
  176. package/lib/server/chromium/chromiumSwitches.js +0 -104
  177. package/lib/server/chromium/crBrowser.js +0 -520
  178. package/lib/server/chromium/crConnection.js +0 -197
  179. package/lib/server/chromium/crCoverage.js +0 -235
  180. package/lib/server/chromium/crDevTools.js +0 -111
  181. package/lib/server/chromium/crDragDrop.js +0 -131
  182. package/lib/server/chromium/crExecutionContext.js +0 -146
  183. package/lib/server/chromium/crInput.js +0 -187
  184. package/lib/server/chromium/crNetworkManager.js +0 -707
  185. package/lib/server/chromium/crPage.js +0 -1001
  186. package/lib/server/chromium/crPdf.js +0 -121
  187. package/lib/server/chromium/crProtocolHelper.js +0 -145
  188. package/lib/server/chromium/crServiceWorker.js +0 -136
  189. package/lib/server/chromium/defaultFontFamilies.js +0 -162
  190. package/lib/server/chromium/protocol.d.js +0 -16
  191. package/lib/server/clock.js +0 -149
  192. package/lib/server/codegen/csharp.js +0 -327
  193. package/lib/server/codegen/java.js +0 -274
  194. package/lib/server/codegen/javascript.js +0 -247
  195. package/lib/server/codegen/jsonl.js +0 -52
  196. package/lib/server/codegen/language.js +0 -133
  197. package/lib/server/codegen/languages.js +0 -68
  198. package/lib/server/codegen/python.js +0 -279
  199. package/lib/server/codegen/types.js +0 -16
  200. package/lib/server/console.js +0 -57
  201. package/lib/server/cookieStore.js +0 -206
  202. package/lib/server/debugController.js +0 -181
  203. package/lib/server/debugger.js +0 -119
  204. package/lib/server/dialog.js +0 -116
  205. package/lib/server/dispatchers/androidDispatcher.js +0 -325
  206. package/lib/server/dispatchers/artifactDispatcher.js +0 -118
  207. package/lib/server/dispatchers/browserContextDispatcher.js +0 -384
  208. package/lib/server/dispatchers/browserDispatcher.js +0 -118
  209. package/lib/server/dispatchers/browserTypeDispatcher.js +0 -64
  210. package/lib/server/dispatchers/cdpSessionDispatcher.js +0 -44
  211. package/lib/server/dispatchers/debugControllerDispatcher.js +0 -78
  212. package/lib/server/dispatchers/dialogDispatcher.js +0 -47
  213. package/lib/server/dispatchers/dispatcher.js +0 -364
  214. package/lib/server/dispatchers/electronDispatcher.js +0 -89
  215. package/lib/server/dispatchers/elementHandlerDispatcher.js +0 -181
  216. package/lib/server/dispatchers/frameDispatcher.js +0 -227
  217. package/lib/server/dispatchers/jsHandleDispatcher.js +0 -85
  218. package/lib/server/dispatchers/jsonPipeDispatcher.js +0 -58
  219. package/lib/server/dispatchers/localUtilsDispatcher.js +0 -149
  220. package/lib/server/dispatchers/networkDispatchers.js +0 -213
  221. package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
  222. package/lib/server/dispatchers/pageDispatcher.js +0 -393
  223. package/lib/server/dispatchers/playwrightDispatcher.js +0 -108
  224. package/lib/server/dispatchers/streamDispatcher.js +0 -67
  225. package/lib/server/dispatchers/tracingDispatcher.js +0 -68
  226. package/lib/server/dispatchers/webSocketRouteDispatcher.js +0 -165
  227. package/lib/server/dispatchers/writableStreamDispatcher.js +0 -79
  228. package/lib/server/dom.js +0 -815
  229. package/lib/server/download.js +0 -70
  230. package/lib/server/electron/electron.js +0 -273
  231. package/lib/server/errors.js +0 -69
  232. package/lib/server/fetch.js +0 -621
  233. package/lib/server/fileChooser.js +0 -43
  234. package/lib/server/fileUploadUtils.js +0 -84
  235. package/lib/server/firefox/ffBrowser.js +0 -418
  236. package/lib/server/firefox/ffConnection.js +0 -142
  237. package/lib/server/firefox/ffExecutionContext.js +0 -150
  238. package/lib/server/firefox/ffInput.js +0 -159
  239. package/lib/server/firefox/ffNetworkManager.js +0 -256
  240. package/lib/server/firefox/ffPage.js +0 -497
  241. package/lib/server/firefox/firefox.js +0 -114
  242. package/lib/server/firefox/protocol.d.js +0 -16
  243. package/lib/server/formData.js +0 -147
  244. package/lib/server/frameSelectors.js +0 -160
  245. package/lib/server/frames.js +0 -1471
  246. package/lib/server/har/harRecorder.js +0 -147
  247. package/lib/server/har/harTracer.js +0 -607
  248. package/lib/server/harBackend.js +0 -157
  249. package/lib/server/helper.js +0 -96
  250. package/lib/server/index.js +0 -58
  251. package/lib/server/input.js +0 -277
  252. package/lib/server/instrumentation.js +0 -72
  253. package/lib/server/javascript.js +0 -291
  254. package/lib/server/launchApp.js +0 -128
  255. package/lib/server/localUtils.js +0 -214
  256. package/lib/server/macEditingCommands.js +0 -143
  257. package/lib/server/network.js +0 -667
  258. package/lib/server/page.js +0 -830
  259. package/lib/server/pipeTransport.js +0 -89
  260. package/lib/server/playwright.js +0 -69
  261. package/lib/server/progress.js +0 -132
  262. package/lib/server/protocolError.js +0 -52
  263. package/lib/server/recorder/chat.js +0 -161
  264. package/lib/server/recorder/recorderApp.js +0 -366
  265. package/lib/server/recorder/recorderRunner.js +0 -138
  266. package/lib/server/recorder/recorderSignalProcessor.js +0 -83
  267. package/lib/server/recorder/recorderUtils.js +0 -157
  268. package/lib/server/recorder/throttledFile.js +0 -57
  269. package/lib/server/recorder.js +0 -554
  270. package/lib/server/registry/browserFetcher.js +0 -177
  271. package/lib/server/registry/dependencies.js +0 -371
  272. package/lib/server/registry/index.js +0 -1422
  273. package/lib/server/registry/nativeDeps.js +0 -1280
  274. package/lib/server/registry/oopDownloadBrowserMain.js +0 -127
  275. package/lib/server/screencast.js +0 -190
  276. package/lib/server/screenshotCompositor.js +0 -153
  277. package/lib/server/screenshotter.js +0 -333
  278. package/lib/server/selectors.js +0 -112
  279. package/lib/server/socksClientCertificatesInterceptor.js +0 -383
  280. package/lib/server/socksInterceptor.js +0 -95
  281. package/lib/server/trace/recorder/snapshotter.js +0 -147
  282. package/lib/server/trace/recorder/snapshotterInjected.js +0 -561
  283. package/lib/server/trace/recorder/tracing.js +0 -604
  284. package/lib/server/trace/viewer/traceParser.js +0 -72
  285. package/lib/server/trace/viewer/traceViewer.js +0 -245
  286. package/lib/server/transport.js +0 -181
  287. package/lib/server/types.js +0 -28
  288. package/lib/server/usKeyboardLayout.js +0 -145
  289. package/lib/server/utils/ascii.js +0 -44
  290. package/lib/server/utils/comparators.js +0 -139
  291. package/lib/server/utils/crypto.js +0 -216
  292. package/lib/server/utils/debug.js +0 -42
  293. package/lib/server/utils/debugLogger.js +0 -122
  294. package/lib/server/utils/env.js +0 -73
  295. package/lib/server/utils/eventsHelper.js +0 -39
  296. package/lib/server/utils/expectUtils.js +0 -123
  297. package/lib/server/utils/fileUtils.js +0 -191
  298. package/lib/server/utils/happyEyeballs.js +0 -207
  299. package/lib/server/utils/hostPlatform.js +0 -138
  300. package/lib/server/utils/httpServer.js +0 -203
  301. package/lib/server/utils/imageUtils.js +0 -141
  302. package/lib/server/utils/image_tools/colorUtils.js +0 -89
  303. package/lib/server/utils/image_tools/compare.js +0 -109
  304. package/lib/server/utils/image_tools/imageChannel.js +0 -78
  305. package/lib/server/utils/image_tools/stats.js +0 -102
  306. package/lib/server/utils/linuxUtils.js +0 -71
  307. package/lib/server/utils/network.js +0 -242
  308. package/lib/server/utils/nodePlatform.js +0 -154
  309. package/lib/server/utils/pipeTransport.js +0 -84
  310. package/lib/server/utils/processLauncher.js +0 -241
  311. package/lib/server/utils/socksProxy.js +0 -511
  312. package/lib/server/utils/spawnAsync.js +0 -41
  313. package/lib/server/utils/task.js +0 -51
  314. package/lib/server/utils/userAgent.js +0 -98
  315. package/lib/server/utils/wsServer.js +0 -121
  316. package/lib/server/utils/zipFile.js +0 -74
  317. package/lib/server/utils/zones.js +0 -57
  318. package/lib/server/videoRecorder.js +0 -124
  319. package/lib/server/webkit/protocol.d.js +0 -16
  320. package/lib/server/webkit/webkit.js +0 -108
  321. package/lib/server/webkit/wkBrowser.js +0 -335
  322. package/lib/server/webkit/wkConnection.js +0 -144
  323. package/lib/server/webkit/wkExecutionContext.js +0 -154
  324. package/lib/server/webkit/wkInput.js +0 -181
  325. package/lib/server/webkit/wkInterceptableRequest.js +0 -197
  326. package/lib/server/webkit/wkPage.js +0 -1159
  327. package/lib/server/webkit/wkProvisionalPage.js +0 -83
  328. package/lib/server/webkit/wkWorkers.js +0 -105
  329. package/lib/third_party/pixelmatch.js +0 -255
  330. package/lib/utils/isomorphic/ariaSnapshot.js +0 -455
  331. package/lib/utils/isomorphic/assert.js +0 -31
  332. package/lib/utils/isomorphic/colors.js +0 -72
  333. package/lib/utils/isomorphic/cssParser.js +0 -245
  334. package/lib/utils/isomorphic/cssTokenizer.js +0 -1051
  335. package/lib/utils/isomorphic/headers.js +0 -53
  336. package/lib/utils/isomorphic/locatorGenerators.js +0 -689
  337. package/lib/utils/isomorphic/locatorParser.js +0 -176
  338. package/lib/utils/isomorphic/locatorUtils.js +0 -81
  339. package/lib/utils/isomorphic/lruCache.js +0 -51
  340. package/lib/utils/isomorphic/manualPromise.js +0 -114
  341. package/lib/utils/isomorphic/mimeType.js +0 -459
  342. package/lib/utils/isomorphic/multimap.js +0 -80
  343. package/lib/utils/isomorphic/protocolFormatter.js +0 -81
  344. package/lib/utils/isomorphic/protocolMetainfo.js +0 -330
  345. package/lib/utils/isomorphic/rtti.js +0 -43
  346. package/lib/utils/isomorphic/selectorParser.js +0 -386
  347. package/lib/utils/isomorphic/semaphore.js +0 -54
  348. package/lib/utils/isomorphic/stackTrace.js +0 -158
  349. package/lib/utils/isomorphic/stringUtils.js +0 -204
  350. package/lib/utils/isomorphic/time.js +0 -49
  351. package/lib/utils/isomorphic/timeoutRunner.js +0 -66
  352. package/lib/utils/isomorphic/trace/entries.js +0 -16
  353. package/lib/utils/isomorphic/trace/snapshotRenderer.js +0 -499
  354. package/lib/utils/isomorphic/trace/snapshotServer.js +0 -120
  355. package/lib/utils/isomorphic/trace/snapshotStorage.js +0 -89
  356. package/lib/utils/isomorphic/trace/traceLoader.js +0 -131
  357. package/lib/utils/isomorphic/trace/traceModel.js +0 -365
  358. package/lib/utils/isomorphic/trace/traceModernizer.js +0 -400
  359. package/lib/utils/isomorphic/trace/versions/traceV3.js +0 -16
  360. package/lib/utils/isomorphic/trace/versions/traceV4.js +0 -16
  361. package/lib/utils/isomorphic/trace/versions/traceV5.js +0 -16
  362. package/lib/utils/isomorphic/trace/versions/traceV6.js +0 -16
  363. package/lib/utils/isomorphic/trace/versions/traceV7.js +0 -16
  364. package/lib/utils/isomorphic/trace/versions/traceV8.js +0 -16
  365. package/lib/utils/isomorphic/traceUtils.js +0 -58
  366. package/lib/utils/isomorphic/types.js +0 -16
  367. package/lib/utils/isomorphic/urlMatch.js +0 -190
  368. package/lib/utils/isomorphic/utilityScriptSerializers.js +0 -251
  369. package/lib/utils/isomorphic/yaml.js +0 -84
  370. package/lib/utils.js +0 -111
  371. package/lib/utilsBundleImpl/index.js +0 -218
  372. package/lib/vite/recorder/assets/index-BSjZa4pk.css +0 -1
  373. package/lib/vite/recorder/assets/index-xK8wYVpV.js +0 -195
  374. package/lib/vite/traceViewer/assets/defaultSettingsView-k0nPICvc.js +0 -266
  375. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
  376. package/lib/vite/traceViewer/index.CVz8LATg.js +0 -2
  377. package/lib/vite/traceViewer/uiMode.C7uDu3VD.js +0 -5
  378. package/lib/zipBundle.js +0 -34
  379. package/lib/zipBundleImpl.js +0 -5
  380. /package/lib/{utilsBundleImpl/xdg-open → xdg-open} +0 -0
package/lib/server/dom.js DELETED
@@ -1,815 +0,0 @@
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 dom_exports = {};
30
- __export(dom_exports, {
31
- ElementHandle: () => ElementHandle,
32
- FrameExecutionContext: () => FrameExecutionContext,
33
- NonRecoverableDOMError: () => NonRecoverableDOMError,
34
- assertDone: () => assertDone,
35
- isNonRecoverableDOMError: () => isNonRecoverableDOMError,
36
- kUnableToAdoptErrorMessage: () => kUnableToAdoptErrorMessage,
37
- throwElementIsNotAttached: () => throwElementIsNotAttached,
38
- throwRetargetableDOMError: () => throwRetargetableDOMError
39
- });
40
- module.exports = __toCommonJS(dom_exports);
41
- var import_fs = __toESM(require("fs"));
42
- var js = __toESM(require("./javascript"));
43
- var import_utils = require("../utils");
44
- var import_fileUploadUtils = require("./fileUploadUtils");
45
- var rawInjectedScriptSource = __toESM(require("../generated/injectedScriptSource"));
46
- class NonRecoverableDOMError extends Error {
47
- }
48
- function isNonRecoverableDOMError(error) {
49
- return error instanceof NonRecoverableDOMError;
50
- }
51
- class FrameExecutionContext extends js.ExecutionContext {
52
- constructor(delegate, frame, world) {
53
- super(frame, delegate, world || "content-script");
54
- this.frame = frame;
55
- this.world = world;
56
- }
57
- adoptIfNeeded(handle) {
58
- if (handle instanceof ElementHandle && handle._context !== this)
59
- return this.frame._page.delegate.adoptElementHandle(handle, this);
60
- return null;
61
- }
62
- async evaluate(pageFunction, arg) {
63
- return js.evaluate(this, true, pageFunction, arg);
64
- }
65
- async evaluateHandle(pageFunction, arg) {
66
- return js.evaluate(this, false, pageFunction, arg);
67
- }
68
- async evaluateExpression(expression, options, arg) {
69
- return js.evaluateExpression(this, expression, { ...options, returnByValue: true }, arg);
70
- }
71
- async evaluateExpressionHandle(expression, options, arg) {
72
- return js.evaluateExpression(this, expression, { ...options, returnByValue: false }, arg);
73
- }
74
- injectedScript() {
75
- if (!this._injectedScriptPromise) {
76
- const customEngines = [];
77
- const selectorsRegistry = this.frame._page.browserContext.selectors();
78
- for (const [name, { source: source2 }] of selectorsRegistry._engines)
79
- customEngines.push({ name, source: `(${source2})` });
80
- const sdkLanguage = this.frame._page.browserContext._browser.sdkLanguage();
81
- const options = {
82
- isUnderTest: (0, import_utils.isUnderTest)(),
83
- sdkLanguage,
84
- testIdAttributeName: selectorsRegistry.testIdAttributeName(),
85
- stableRafCount: this.frame._page.delegate.rafCountForStablePosition(),
86
- browserName: this.frame._page.browserContext._browser.options.name,
87
- isUtilityWorld: this.world === "utility",
88
- customEngines
89
- };
90
- const source = `
91
- (() => {
92
- const module = {};
93
- ${rawInjectedScriptSource.source}
94
- return new (module.exports.InjectedScript())(globalThis, ${JSON.stringify(options)});
95
- })();
96
- `;
97
- this._injectedScriptPromise = this.rawEvaluateHandle(source).then((handle) => {
98
- handle._setPreview("InjectedScript");
99
- return handle;
100
- });
101
- }
102
- return this._injectedScriptPromise;
103
- }
104
- }
105
- class ElementHandle extends js.JSHandle {
106
- constructor(context, objectId) {
107
- super(context, "node", void 0, objectId);
108
- this.__elementhandle = true;
109
- this._page = context.frame._page;
110
- this._frame = context.frame;
111
- this._initializePreview().catch((e) => {
112
- });
113
- }
114
- async _initializePreview() {
115
- const utility = await this._context.injectedScript();
116
- this._setPreview(await utility.evaluate((injected, e) => "JSHandle@" + injected.previewNode(e), this));
117
- }
118
- asElement() {
119
- return this;
120
- }
121
- async evaluateInUtility(pageFunction, arg) {
122
- try {
123
- const utility = await this._frame._utilityContext();
124
- return await utility.evaluate(pageFunction, [await utility.injectedScript(), this, arg]);
125
- } catch (e) {
126
- if (this._frame.isNonRetriableError(e))
127
- throw e;
128
- return "error:notconnected";
129
- }
130
- }
131
- async evaluateHandleInUtility(pageFunction, arg) {
132
- try {
133
- const utility = await this._frame._utilityContext();
134
- return await utility.evaluateHandle(pageFunction, [await utility.injectedScript(), this, arg]);
135
- } catch (e) {
136
- if (this._frame.isNonRetriableError(e))
137
- throw e;
138
- return "error:notconnected";
139
- }
140
- }
141
- async ownerFrame() {
142
- const frameId = await this._page.delegate.getOwnerFrame(this);
143
- if (!frameId)
144
- return null;
145
- const frame = this._page.frameManager.frame(frameId);
146
- if (frame)
147
- return frame;
148
- for (const page of this._page.browserContext.pages()) {
149
- const frame2 = page.frameManager.frame(frameId);
150
- if (frame2)
151
- return frame2;
152
- }
153
- return null;
154
- }
155
- async isIframeElement() {
156
- return this.evaluateInUtility(([injected, node]) => node && (node.nodeName === "IFRAME" || node.nodeName === "FRAME"), {});
157
- }
158
- async contentFrame() {
159
- const isFrameElement = throwRetargetableDOMError(await this.isIframeElement());
160
- if (!isFrameElement)
161
- return null;
162
- return this._page.delegate.getContentFrame(this);
163
- }
164
- async getAttribute(progress, name) {
165
- return this._frame.getAttribute(progress, ":scope", name, {}, this);
166
- }
167
- async inputValue(progress) {
168
- return this._frame.inputValue(progress, ":scope", {}, this);
169
- }
170
- async textContent(progress) {
171
- return this._frame.textContent(progress, ":scope", {}, this);
172
- }
173
- async innerText(progress) {
174
- return this._frame.innerText(progress, ":scope", {}, this);
175
- }
176
- async innerHTML(progress) {
177
- return this._frame.innerHTML(progress, ":scope", {}, this);
178
- }
179
- async dispatchEvent(progress, type, eventInit = {}) {
180
- return this._frame.dispatchEvent(progress, ":scope", type, eventInit, {}, this);
181
- }
182
- async _scrollRectIntoViewIfNeeded(progress, rect) {
183
- return await progress.race(this._page.delegate.scrollRectIntoViewIfNeeded(this, rect));
184
- }
185
- async _waitAndScrollIntoViewIfNeeded(progress, waitForVisible) {
186
- const result = await this._retryAction(progress, "scroll into view", async () => {
187
- progress.log(` waiting for element to be stable`);
188
- const waitResult = await progress.race(this.evaluateInUtility(async ([injected, node, { waitForVisible: waitForVisible2 }]) => {
189
- return await injected.checkElementStates(node, waitForVisible2 ? ["visible", "stable"] : ["stable"]);
190
- }, { waitForVisible }));
191
- if (waitResult)
192
- return waitResult;
193
- return await this._scrollRectIntoViewIfNeeded(progress);
194
- }, {});
195
- assertDone(throwRetargetableDOMError(result));
196
- }
197
- async scrollIntoViewIfNeeded(progress) {
198
- await this._waitAndScrollIntoViewIfNeeded(
199
- progress,
200
- false
201
- /* waitForVisible */
202
- );
203
- }
204
- async _clickablePoint() {
205
- const intersectQuadWithViewport = (quad) => {
206
- return quad.map((point) => ({
207
- x: Math.min(Math.max(point.x, 0), metrics.width),
208
- y: Math.min(Math.max(point.y, 0), metrics.height)
209
- }));
210
- };
211
- const computeQuadArea = (quad) => {
212
- let area = 0;
213
- for (let i = 0; i < quad.length; ++i) {
214
- const p1 = quad[i];
215
- const p2 = quad[(i + 1) % quad.length];
216
- area += (p1.x * p2.y - p2.x * p1.y) / 2;
217
- }
218
- return Math.abs(area);
219
- };
220
- const [quads, metrics] = await Promise.all([
221
- this._page.delegate.getContentQuads(this),
222
- this._page.mainFrame()._utilityContext().then((utility) => utility.evaluate(() => ({ width: innerWidth, height: innerHeight })))
223
- ]);
224
- if (quads === "error:notconnected")
225
- return quads;
226
- if (!quads || !quads.length)
227
- return "error:notvisible";
228
- const filtered = quads.map((quad) => intersectQuadWithViewport(quad)).filter((quad) => computeQuadArea(quad) > 0.99);
229
- if (!filtered.length)
230
- return "error:notinviewport";
231
- if (this._page.browserContext._browser.options.name === "firefox") {
232
- for (const quad of filtered) {
233
- const integerPoint = findIntegerPointInsideQuad(quad);
234
- if (integerPoint)
235
- return integerPoint;
236
- }
237
- }
238
- return quadMiddlePoint(filtered[0]);
239
- }
240
- async _offsetPoint(offset) {
241
- const [box, border] = await Promise.all([
242
- this.boundingBox(),
243
- this.evaluateInUtility(([injected, node]) => injected.getElementBorderWidth(node), {}).catch((e) => {
244
- })
245
- ]);
246
- if (!box || !border)
247
- return "error:notvisible";
248
- if (border === "error:notconnected")
249
- return border;
250
- return {
251
- x: box.x + border.left + offset.x,
252
- y: box.y + border.top + offset.y
253
- };
254
- }
255
- async _retryAction(progress, actionName, action, options) {
256
- let retry = 0;
257
- const waitTime = [0, 20, 100, 100, 500];
258
- const noAutoWaiting = options.__testHookNoAutoWaiting ?? options.noAutoWaiting;
259
- while (true) {
260
- if (retry) {
261
- progress.log(`retrying ${actionName} action${options.trial ? " (trial run)" : ""}`);
262
- const timeout = waitTime[Math.min(retry - 1, waitTime.length - 1)];
263
- if (timeout) {
264
- progress.log(` waiting ${timeout}ms`);
265
- const result2 = await progress.race(this.evaluateInUtility(([injected, node, timeout2]) => new Promise((f) => setTimeout(f, timeout2)), timeout));
266
- if (result2 === "error:notconnected")
267
- return result2;
268
- }
269
- } else {
270
- progress.log(`attempting ${actionName} action${options.trial ? " (trial run)" : ""}`);
271
- }
272
- if (!options.skipActionPreChecks && !options.force && !noAutoWaiting)
273
- await this._frame._page.performActionPreChecks(progress);
274
- const result = await action(retry);
275
- ++retry;
276
- if (result === "error:notvisible") {
277
- if (options.force || noAutoWaiting)
278
- throw new NonRecoverableDOMError("Element is not visible");
279
- progress.log(" element is not visible");
280
- continue;
281
- }
282
- if (result === "error:notinviewport") {
283
- if (options.force || noAutoWaiting)
284
- throw new NonRecoverableDOMError("Element is outside of the viewport");
285
- progress.log(" element is outside of the viewport");
286
- continue;
287
- }
288
- if (result === "error:optionsnotfound") {
289
- if (noAutoWaiting)
290
- throw new NonRecoverableDOMError("Did not find some options");
291
- progress.log(" did not find some options");
292
- continue;
293
- }
294
- if (result === "error:optionnotenabled") {
295
- if (noAutoWaiting)
296
- throw new NonRecoverableDOMError("Option being selected is not enabled");
297
- progress.log(" option being selected is not enabled");
298
- continue;
299
- }
300
- if (typeof result === "object" && "hitTargetDescription" in result) {
301
- if (noAutoWaiting)
302
- throw new NonRecoverableDOMError(`${result.hitTargetDescription} intercepts pointer events`);
303
- progress.log(` ${result.hitTargetDescription} intercepts pointer events`);
304
- continue;
305
- }
306
- if (typeof result === "object" && "missingState" in result) {
307
- if (noAutoWaiting)
308
- throw new NonRecoverableDOMError(`Element is not ${result.missingState}`);
309
- progress.log(` element is not ${result.missingState}`);
310
- continue;
311
- }
312
- return result;
313
- }
314
- }
315
- async _retryPointerAction(progress, actionName, waitForEnabled, action, options) {
316
- const skipActionPreChecks = actionName === "move and up";
317
- return await this._retryAction(progress, actionName, async (retry) => {
318
- const scrollOptions = [
319
- void 0,
320
- { block: "end", inline: "end" },
321
- { block: "center", inline: "center" },
322
- { block: "start", inline: "start" }
323
- ];
324
- const forceScrollOptions = scrollOptions[retry % scrollOptions.length];
325
- return await this._performPointerAction(progress, actionName, waitForEnabled, action, forceScrollOptions, options);
326
- }, { ...options, skipActionPreChecks });
327
- }
328
- async _performPointerAction(progress, actionName, waitForEnabled, action, forceScrollOptions, options) {
329
- const { force = false, position } = options;
330
- const doScrollIntoView = async () => {
331
- if (forceScrollOptions) {
332
- return await this.evaluateInUtility(([injected, node, options2]) => {
333
- if (node.nodeType === 1)
334
- node.scrollIntoView(options2);
335
- return "done";
336
- }, forceScrollOptions);
337
- }
338
- return await this._scrollRectIntoViewIfNeeded(progress, position ? { x: position.x, y: position.y, width: 0, height: 0 } : void 0);
339
- };
340
- if (this._frame.parentFrame()) {
341
- await progress.race(doScrollIntoView().catch(() => {
342
- }));
343
- }
344
- if (options.__testHookBeforeStable)
345
- await progress.race(options.__testHookBeforeStable());
346
- if (!force) {
347
- const elementStates = waitForEnabled ? ["visible", "enabled", "stable"] : ["visible", "stable"];
348
- progress.log(` waiting for element to be ${waitForEnabled ? "visible, enabled and stable" : "visible and stable"}`);
349
- const result = await progress.race(this.evaluateInUtility(async ([injected, node, { elementStates: elementStates2 }]) => {
350
- return await injected.checkElementStates(node, elementStates2);
351
- }, { elementStates }));
352
- if (result)
353
- return result;
354
- progress.log(` element is ${waitForEnabled ? "visible, enabled and stable" : "visible and stable"}`);
355
- }
356
- if (options.__testHookAfterStable)
357
- await progress.race(options.__testHookAfterStable());
358
- progress.log(" scrolling into view if needed");
359
- const scrolled = await progress.race(doScrollIntoView());
360
- if (scrolled !== "done")
361
- return scrolled;
362
- progress.log(" done scrolling");
363
- const maybePoint = position ? await progress.race(this._offsetPoint(position)) : await progress.race(this._clickablePoint());
364
- if (typeof maybePoint === "string")
365
- return maybePoint;
366
- const point = roundPoint(maybePoint);
367
- progress.metadata.point = point;
368
- await progress.race(this.instrumentation.onBeforeInputAction(this, progress.metadata));
369
- let hitTargetInterceptionHandle;
370
- if (force) {
371
- progress.log(` forcing action`);
372
- } else {
373
- if (options.__testHookBeforeHitTarget)
374
- await progress.race(options.__testHookBeforeHitTarget());
375
- const frameCheckResult = await progress.race(this._checkFrameIsHitTarget(point));
376
- if (frameCheckResult === "error:notconnected" || "hitTargetDescription" in frameCheckResult)
377
- return frameCheckResult;
378
- const hitPoint = frameCheckResult.framePoint;
379
- const actionType = actionName === "move and up" ? "drag" : actionName === "hover" || actionName === "tap" ? actionName : "mouse";
380
- const handle = await progress.race(this.evaluateHandleInUtility(([injected, node, { actionType: actionType2, hitPoint: hitPoint2, trial }]) => injected.setupHitTargetInterceptor(node, actionType2, hitPoint2, trial), { actionType, hitPoint, trial: !!options.trial }));
381
- if (handle === "error:notconnected")
382
- return handle;
383
- if (!handle._objectId) {
384
- const error = handle.rawValue();
385
- if (error === "error:notconnected")
386
- return error;
387
- return { hitTargetDescription: error };
388
- }
389
- hitTargetInterceptionHandle = handle;
390
- }
391
- const actionResult = await this._page.frameManager.waitForSignalsCreatedBy(progress, options.waitAfter === true, async () => {
392
- if (options.__testHookBeforePointerAction)
393
- await progress.race(options.__testHookBeforePointerAction());
394
- let restoreModifiers;
395
- if (options && options.modifiers)
396
- restoreModifiers = await this._page.keyboard.ensureModifiers(progress, options.modifiers);
397
- progress.log(` performing ${actionName} action`);
398
- await action(point);
399
- if (restoreModifiers)
400
- await this._page.keyboard.ensureModifiers(progress, restoreModifiers);
401
- if (hitTargetInterceptionHandle) {
402
- const stopHitTargetInterception = this._frame.raceAgainstEvaluationStallingEvents(() => {
403
- return hitTargetInterceptionHandle.evaluate((h) => h.stop());
404
- }).catch((e) => "done").finally(() => {
405
- hitTargetInterceptionHandle?.dispose();
406
- });
407
- if (options.waitAfter !== false) {
408
- const hitTargetResult = await progress.race(stopHitTargetInterception);
409
- if (hitTargetResult !== "done")
410
- return hitTargetResult;
411
- }
412
- }
413
- progress.log(` ${options.trial ? "trial " : ""}${actionName} action done`);
414
- progress.log(" waiting for scheduled navigations to finish");
415
- if (options.__testHookAfterPointerAction)
416
- await progress.race(options.__testHookAfterPointerAction());
417
- return "done";
418
- }).finally(() => {
419
- const stopPromise = hitTargetInterceptionHandle?.evaluate((h) => h.stop()).catch(() => {
420
- });
421
- stopPromise?.then(() => hitTargetInterceptionHandle?.dispose());
422
- });
423
- if (actionResult !== "done")
424
- return actionResult;
425
- progress.log(" navigations have finished");
426
- return "done";
427
- }
428
- async _markAsTargetElement(progress) {
429
- if (!progress.metadata.id)
430
- return;
431
- await progress.race(this.evaluateInUtility(([injected, node, callId]) => {
432
- if (node.nodeType === 1)
433
- injected.markTargetElements(/* @__PURE__ */ new Set([node]), callId);
434
- }, progress.metadata.id));
435
- }
436
- async hover(progress, options) {
437
- await this._markAsTargetElement(progress);
438
- const result = await this._hover(progress, options);
439
- return assertDone(throwRetargetableDOMError(result));
440
- }
441
- _hover(progress, options) {
442
- return this._retryPointerAction(progress, "hover", false, (point) => this._page.mouse.move(progress, point.x, point.y), { ...options, waitAfter: "disabled" });
443
- }
444
- async click(progress, options) {
445
- await this._markAsTargetElement(progress);
446
- const result = await this._click(progress, { ...options, waitAfter: !options.noWaitAfter });
447
- return assertDone(throwRetargetableDOMError(result));
448
- }
449
- _click(progress, options) {
450
- return this._retryPointerAction(progress, "click", true, (point) => this._page.mouse.click(progress, point.x, point.y, options), options);
451
- }
452
- async dblclick(progress, options) {
453
- await this._markAsTargetElement(progress);
454
- const result = await this._dblclick(progress, options);
455
- return assertDone(throwRetargetableDOMError(result));
456
- }
457
- _dblclick(progress, options) {
458
- return this._retryPointerAction(progress, "dblclick", true, (point) => this._page.mouse.click(progress, point.x, point.y, { ...options, clickCount: 2 }), { ...options, waitAfter: "disabled" });
459
- }
460
- async tap(progress, options) {
461
- await this._markAsTargetElement(progress);
462
- const result = await this._tap(progress, options);
463
- return assertDone(throwRetargetableDOMError(result));
464
- }
465
- _tap(progress, options) {
466
- return this._retryPointerAction(progress, "tap", true, (point) => this._page.touchscreen.tap(progress, point.x, point.y), { ...options, waitAfter: "disabled" });
467
- }
468
- async selectOption(progress, elements, values, options) {
469
- await this._markAsTargetElement(progress);
470
- const result = await this._selectOption(progress, elements, values, options);
471
- return throwRetargetableDOMError(result);
472
- }
473
- async _selectOption(progress, elements, values, options) {
474
- let resultingOptions = [];
475
- const result = await this._retryAction(progress, "select option", async () => {
476
- await progress.race(this.instrumentation.onBeforeInputAction(this, progress.metadata));
477
- if (!options.force)
478
- progress.log(` waiting for element to be visible and enabled`);
479
- const optionsToSelect = [...elements, ...values];
480
- const result2 = await progress.race(this.evaluateInUtility(async ([injected, node, { optionsToSelect: optionsToSelect2, force }]) => {
481
- if (!force) {
482
- const checkResult = await injected.checkElementStates(node, ["visible", "enabled"]);
483
- if (checkResult)
484
- return checkResult;
485
- }
486
- return injected.selectOptions(node, optionsToSelect2);
487
- }, { optionsToSelect, force: options.force }));
488
- if (Array.isArray(result2)) {
489
- progress.log(" selected specified option(s)");
490
- resultingOptions = result2;
491
- return "done";
492
- }
493
- return result2;
494
- }, options);
495
- if (result === "error:notconnected")
496
- return result;
497
- return resultingOptions;
498
- }
499
- async fill(progress, value, options) {
500
- await this._markAsTargetElement(progress);
501
- const result = await this._fill(progress, value, options);
502
- assertDone(throwRetargetableDOMError(result));
503
- }
504
- async _fill(progress, value, options) {
505
- progress.log(` fill("${value}")`);
506
- return await this._retryAction(progress, "fill", async () => {
507
- await progress.race(this.instrumentation.onBeforeInputAction(this, progress.metadata));
508
- if (!options.force)
509
- progress.log(" waiting for element to be visible, enabled and editable");
510
- const result = await progress.race(this.evaluateInUtility(async ([injected, node, { value: value2, force }]) => {
511
- if (!force) {
512
- const checkResult = await injected.checkElementStates(node, ["visible", "enabled", "editable"]);
513
- if (checkResult)
514
- return checkResult;
515
- }
516
- return injected.fill(node, value2);
517
- }, { value, force: options.force }));
518
- if (result === "needsinput") {
519
- if (value)
520
- await this._page.keyboard.insertText(progress, value);
521
- else
522
- await this._page.keyboard.press(progress, "Delete");
523
- return "done";
524
- } else {
525
- return result;
526
- }
527
- }, options);
528
- }
529
- async selectText(progress, options) {
530
- const result = await this._retryAction(progress, "selectText", async () => {
531
- if (!options.force)
532
- progress.log(" waiting for element to be visible");
533
- return await progress.race(this.evaluateInUtility(async ([injected, node, { force }]) => {
534
- if (!force) {
535
- const checkResult = await injected.checkElementStates(node, ["visible"]);
536
- if (checkResult)
537
- return checkResult;
538
- }
539
- return injected.selectText(node);
540
- }, { force: options.force }));
541
- }, options);
542
- assertDone(throwRetargetableDOMError(result));
543
- }
544
- async setInputFiles(progress, params) {
545
- const inputFileItems = await progress.race((0, import_fileUploadUtils.prepareFilesForUpload)(this._frame, params));
546
- await this._markAsTargetElement(progress);
547
- const result = await this._setInputFiles(progress, inputFileItems);
548
- return assertDone(throwRetargetableDOMError(result));
549
- }
550
- async _setInputFiles(progress, items) {
551
- const { filePayloads, localPaths, localDirectory } = items;
552
- const multiple = filePayloads && filePayloads.length > 1 || localPaths && localPaths.length > 1;
553
- const result = await progress.race(this.evaluateHandleInUtility(([injected, node, { multiple: multiple2, directoryUpload }]) => {
554
- const element = injected.retarget(node, "follow-label");
555
- if (!element)
556
- return;
557
- if (element.tagName !== "INPUT")
558
- throw injected.createStacklessError("Node is not an HTMLInputElement");
559
- const inputElement = element;
560
- if (multiple2 && !inputElement.multiple && !inputElement.webkitdirectory)
561
- throw injected.createStacklessError("Non-multiple file input can only accept single file");
562
- if (directoryUpload && !inputElement.webkitdirectory)
563
- throw injected.createStacklessError("File input does not support directories, pass individual files instead");
564
- if (!directoryUpload && inputElement.webkitdirectory)
565
- throw injected.createStacklessError("[webkitdirectory] input requires passing a path to a directory");
566
- return inputElement;
567
- }, { multiple, directoryUpload: !!localDirectory }));
568
- if (result === "error:notconnected" || !result.asElement())
569
- return "error:notconnected";
570
- const retargeted = result.asElement();
571
- await progress.race(this.instrumentation.onBeforeInputAction(this, progress.metadata));
572
- if (localPaths || localDirectory) {
573
- const localPathsOrDirectory = localDirectory ? [localDirectory] : localPaths;
574
- await progress.race(Promise.all(localPathsOrDirectory.map((localPath) => import_fs.default.promises.access(localPath, import_fs.default.constants.F_OK))));
575
- const waitForInputEvent = localDirectory ? this.evaluate((node) => new Promise((fulfill) => {
576
- node.addEventListener("input", fulfill, { once: true });
577
- })).catch(() => {
578
- }) : Promise.resolve();
579
- await progress.race(this._page.delegate.setInputFilePaths(retargeted, localPathsOrDirectory));
580
- await progress.race(waitForInputEvent);
581
- } else {
582
- await progress.race(retargeted.evaluateInUtility(([injected, node, files]) => injected.setInputFiles(node, files), filePayloads));
583
- }
584
- return "done";
585
- }
586
- async focus(progress) {
587
- await this._markAsTargetElement(progress);
588
- const result = await this._focus(progress);
589
- return assertDone(throwRetargetableDOMError(result));
590
- }
591
- async _focus(progress, resetSelectionIfNotFocused) {
592
- return await progress.race(this.evaluateInUtility(([injected, node, resetSelectionIfNotFocused2]) => injected.focusNode(node, resetSelectionIfNotFocused2), resetSelectionIfNotFocused));
593
- }
594
- async _blur(progress) {
595
- return await progress.race(this.evaluateInUtility(([injected, node]) => injected.blurNode(node), {}));
596
- }
597
- async type(progress, text, options) {
598
- await this._markAsTargetElement(progress);
599
- const result = await this._type(progress, text, options);
600
- return assertDone(throwRetargetableDOMError(result));
601
- }
602
- async _type(progress, text, options) {
603
- progress.log(`elementHandle.type("${text}")`);
604
- await progress.race(this.instrumentation.onBeforeInputAction(this, progress.metadata));
605
- const result = await this._focus(
606
- progress,
607
- true
608
- /* resetSelectionIfNotFocused */
609
- );
610
- if (result !== "done")
611
- return result;
612
- await this._page.keyboard.type(progress, text, options);
613
- return "done";
614
- }
615
- async press(progress, key, options) {
616
- await this._markAsTargetElement(progress);
617
- const result = await this._press(progress, key, options);
618
- return assertDone(throwRetargetableDOMError(result));
619
- }
620
- async _press(progress, key, options) {
621
- progress.log(`elementHandle.press("${key}")`);
622
- await progress.race(this.instrumentation.onBeforeInputAction(this, progress.metadata));
623
- return this._page.frameManager.waitForSignalsCreatedBy(progress, !options.noWaitAfter, async () => {
624
- const result = await this._focus(
625
- progress,
626
- true
627
- /* resetSelectionIfNotFocused */
628
- );
629
- if (result !== "done")
630
- return result;
631
- await this._page.keyboard.press(progress, key, options);
632
- return "done";
633
- });
634
- }
635
- async check(progress, options) {
636
- const result = await this._setChecked(progress, true, options);
637
- return assertDone(throwRetargetableDOMError(result));
638
- }
639
- async uncheck(progress, options) {
640
- const result = await this._setChecked(progress, false, options);
641
- return assertDone(throwRetargetableDOMError(result));
642
- }
643
- async _setChecked(progress, state, options) {
644
- const isChecked = async () => {
645
- const result2 = await progress.race(this.evaluateInUtility(([injected, node]) => injected.elementState(node, "checked"), {}));
646
- if (result2 === "error:notconnected" || result2.received === "error:notconnected")
647
- throwElementIsNotAttached();
648
- return { matches: result2.matches, isRadio: result2.isRadio };
649
- };
650
- await this._markAsTargetElement(progress);
651
- const checkedState = await isChecked();
652
- if (checkedState.matches === state)
653
- return "done";
654
- if (!state && checkedState.isRadio)
655
- throw new NonRecoverableDOMError("Cannot uncheck radio button. Radio buttons can only be unchecked by selecting another radio button in the same group.");
656
- const result = await this._click(progress, { ...options, waitAfter: "disabled" });
657
- if (result !== "done")
658
- return result;
659
- if (options.trial)
660
- return "done";
661
- const finalState = await isChecked();
662
- if (finalState.matches !== state)
663
- throw new NonRecoverableDOMError("Clicking the checkbox did not change its state");
664
- return "done";
665
- }
666
- async boundingBox() {
667
- return this._page.delegate.getBoundingBox(this);
668
- }
669
- async ariaSnapshot() {
670
- return await this.evaluateInUtility(([injected, element]) => injected.ariaSnapshot(element, { mode: "expect" }), {});
671
- }
672
- async screenshot(progress, options) {
673
- return await this._page.screenshotter.screenshotElement(progress, this, options);
674
- }
675
- async querySelector(selector, options) {
676
- return this._frame.selectors.query(selector, options, this);
677
- }
678
- async querySelectorAll(selector) {
679
- return this._frame.selectors.queryAll(selector, this);
680
- }
681
- async evalOnSelector(selector, strict, expression, isFunction, arg) {
682
- return this._frame.evalOnSelector(selector, strict, expression, isFunction, arg, this);
683
- }
684
- async evalOnSelectorAll(selector, expression, isFunction, arg) {
685
- return this._frame.evalOnSelectorAll(selector, expression, isFunction, arg, this);
686
- }
687
- async isVisible(progress) {
688
- return this._frame.isVisible(progress, ":scope", {}, this);
689
- }
690
- async isHidden(progress) {
691
- return this._frame.isHidden(progress, ":scope", {}, this);
692
- }
693
- async isEnabled(progress) {
694
- return this._frame.isEnabled(progress, ":scope", {}, this);
695
- }
696
- async isDisabled(progress) {
697
- return this._frame.isDisabled(progress, ":scope", {}, this);
698
- }
699
- async isEditable(progress) {
700
- return this._frame.isEditable(progress, ":scope", {}, this);
701
- }
702
- async isChecked(progress) {
703
- return this._frame.isChecked(progress, ":scope", {}, this);
704
- }
705
- async waitForElementState(progress, state) {
706
- const actionName = `wait for ${state}`;
707
- const result = await this._retryAction(progress, actionName, async () => {
708
- return await progress.race(this.evaluateInUtility(async ([injected, node, state2]) => {
709
- return await injected.checkElementStates(node, [state2]) || "done";
710
- }, state));
711
- }, {});
712
- assertDone(throwRetargetableDOMError(result));
713
- }
714
- async waitForSelector(progress, selector, options) {
715
- return await this._frame.waitForSelector(progress, selector, true, options, this);
716
- }
717
- async _adoptTo(context) {
718
- if (this._context !== context) {
719
- const adopted = await this._page.delegate.adoptElementHandle(this, context);
720
- this.dispose();
721
- return adopted;
722
- }
723
- return this;
724
- }
725
- async _checkFrameIsHitTarget(point) {
726
- let frame = this._frame;
727
- const data = [];
728
- while (frame.parentFrame()) {
729
- const frameElement = await frame.frameElement();
730
- const box = await frameElement.boundingBox();
731
- const style = await frameElement.evaluateInUtility(([injected, iframe]) => injected.describeIFrameStyle(iframe), {}).catch((e) => "error:notconnected");
732
- if (!box || style === "error:notconnected")
733
- return "error:notconnected";
734
- if (style === "transformed") {
735
- return { framePoint: void 0 };
736
- }
737
- const pointInFrame = { x: point.x - box.x - style.left, y: point.y - box.y - style.top };
738
- data.push({ frame, frameElement, pointInFrame });
739
- frame = frame.parentFrame();
740
- }
741
- data.push({ frame, frameElement: null, pointInFrame: point });
742
- for (let i = data.length - 1; i > 0; i--) {
743
- const element = data[i - 1].frameElement;
744
- const point2 = data[i].pointInFrame;
745
- const hitTargetResult = await element.evaluateInUtility(([injected, element2, hitPoint]) => {
746
- return injected.expectHitTarget(hitPoint, element2);
747
- }, point2);
748
- if (hitTargetResult !== "done")
749
- return hitTargetResult;
750
- }
751
- return { framePoint: data[0].pointInFrame };
752
- }
753
- }
754
- function throwRetargetableDOMError(result) {
755
- if (result === "error:notconnected")
756
- throwElementIsNotAttached();
757
- return result;
758
- }
759
- function throwElementIsNotAttached() {
760
- throw new Error("Element is not attached to the DOM");
761
- }
762
- function assertDone(result) {
763
- }
764
- function roundPoint(point) {
765
- return {
766
- x: (point.x * 100 | 0) / 100,
767
- y: (point.y * 100 | 0) / 100
768
- };
769
- }
770
- function quadMiddlePoint(quad) {
771
- const result = { x: 0, y: 0 };
772
- for (const point of quad) {
773
- result.x += point.x / 4;
774
- result.y += point.y / 4;
775
- }
776
- return result;
777
- }
778
- function triangleArea(p1, p2, p3) {
779
- return Math.abs(p1.x * (p2.y - p3.y) + p2.x * (p3.y - p1.y) + p3.x * (p1.y - p2.y)) / 2;
780
- }
781
- function isPointInsideQuad(point, quad) {
782
- const area1 = triangleArea(point, quad[0], quad[1]) + triangleArea(point, quad[1], quad[2]) + triangleArea(point, quad[2], quad[3]) + triangleArea(point, quad[3], quad[0]);
783
- const area2 = triangleArea(quad[0], quad[1], quad[2]) + triangleArea(quad[1], quad[2], quad[3]);
784
- if (Math.abs(area1 - area2) > 0.1)
785
- return false;
786
- return point.x < Math.max(quad[0].x, quad[1].x, quad[2].x, quad[3].x) && point.y < Math.max(quad[0].y, quad[1].y, quad[2].y, quad[3].y);
787
- }
788
- function findIntegerPointInsideQuad(quad) {
789
- const point = quadMiddlePoint(quad);
790
- point.x = Math.floor(point.x);
791
- point.y = Math.floor(point.y);
792
- if (isPointInsideQuad(point, quad))
793
- return point;
794
- point.x += 1;
795
- if (isPointInsideQuad(point, quad))
796
- return point;
797
- point.y += 1;
798
- if (isPointInsideQuad(point, quad))
799
- return point;
800
- point.x -= 1;
801
- if (isPointInsideQuad(point, quad))
802
- return point;
803
- }
804
- const kUnableToAdoptErrorMessage = "Unable to adopt element handle from a different document";
805
- // Annotate the CommonJS export names for ESM import in node:
806
- 0 && (module.exports = {
807
- ElementHandle,
808
- FrameExecutionContext,
809
- NonRecoverableDOMError,
810
- assertDone,
811
- isNonRecoverableDOMError,
812
- kUnableToAdoptErrorMessage,
813
- throwElementIsNotAttached,
814
- throwRetargetableDOMError
815
- });