pokeedex 0.1.0 → 0.1.5

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 (560) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +3 -5
  3. data/bin/pokeedex +1 -44
  4. data/lib/pokeedex/configuration.rb +0 -6
  5. data/lib/pokeedex/install_playwright.rb +62 -0
  6. data/lib/pokeedex/pokemon/scrapper/fetchers/base.rb +1 -1
  7. data/lib/pokeedex/version.rb +1 -1
  8. data/lib/pokeedex.rb +5 -2
  9. data/spec/pokeedex/configuration_spec.rb +0 -7
  10. data/spec/spec_helper.rb +1 -1
  11. metadata +2 -550
  12. data/node_modules/.bin/playwright +0 -1
  13. data/node_modules/.bin/playwright-core +0 -1
  14. data/node_modules/.yarn-integrity +0 -22
  15. data/node_modules/@playwright/test/LICENSE +0 -202
  16. data/node_modules/@playwright/test/NOTICE +0 -5
  17. data/node_modules/@playwright/test/README.md +0 -169
  18. data/node_modules/@playwright/test/cli.js +0 -19
  19. data/node_modules/@playwright/test/index.d.ts +0 -18
  20. data/node_modules/@playwright/test/index.js +0 -17
  21. data/node_modules/@playwright/test/index.mjs +0 -18
  22. data/node_modules/@playwright/test/node_modules/.bin/playwright +0 -1
  23. data/node_modules/@playwright/test/package.json +0 -35
  24. data/node_modules/@playwright/test/reporter.d.ts +0 -17
  25. data/node_modules/@playwright/test/reporter.js +0 -17
  26. data/node_modules/@playwright/test/reporter.mjs +0 -17
  27. data/node_modules/@types/node/LICENSE +0 -21
  28. data/node_modules/@types/node/README.md +0 -15
  29. data/node_modules/@types/node/assert/strict.d.ts +0 -8
  30. data/node_modules/@types/node/assert.d.ts +0 -1040
  31. data/node_modules/@types/node/async_hooks.d.ts +0 -541
  32. data/node_modules/@types/node/buffer.d.ts +0 -2300
  33. data/node_modules/@types/node/child_process.d.ts +0 -1544
  34. data/node_modules/@types/node/cluster.d.ts +0 -578
  35. data/node_modules/@types/node/console.d.ts +0 -452
  36. data/node_modules/@types/node/constants.d.ts +0 -19
  37. data/node_modules/@types/node/crypto.d.ts +0 -4451
  38. data/node_modules/@types/node/dgram.d.ts +0 -596
  39. data/node_modules/@types/node/diagnostics_channel.d.ts +0 -554
  40. data/node_modules/@types/node/dns/promises.d.ts +0 -476
  41. data/node_modules/@types/node/dns.d.ts +0 -865
  42. data/node_modules/@types/node/dom-events.d.ts +0 -124
  43. data/node_modules/@types/node/domain.d.ts +0 -170
  44. data/node_modules/@types/node/events.d.ts +0 -931
  45. data/node_modules/@types/node/fs/promises.d.ts +0 -1264
  46. data/node_modules/@types/node/fs.d.ts +0 -4390
  47. data/node_modules/@types/node/globals.d.ts +0 -611
  48. data/node_modules/@types/node/globals.global.d.ts +0 -1
  49. data/node_modules/@types/node/http.d.ts +0 -1921
  50. data/node_modules/@types/node/http2.d.ts +0 -2555
  51. data/node_modules/@types/node/https.d.ts +0 -544
  52. data/node_modules/@types/node/index.d.ts +0 -90
  53. data/node_modules/@types/node/inspector.d.ts +0 -3966
  54. data/node_modules/@types/node/module.d.ts +0 -301
  55. data/node_modules/@types/node/net.d.ts +0 -995
  56. data/node_modules/@types/node/os.d.ts +0 -495
  57. data/node_modules/@types/node/package.json +0 -217
  58. data/node_modules/@types/node/path.d.ts +0 -200
  59. data/node_modules/@types/node/perf_hooks.d.ts +0 -941
  60. data/node_modules/@types/node/process.d.ts +0 -1912
  61. data/node_modules/@types/node/punycode.d.ts +0 -117
  62. data/node_modules/@types/node/querystring.d.ts +0 -153
  63. data/node_modules/@types/node/readline/promises.d.ts +0 -150
  64. data/node_modules/@types/node/readline.d.ts +0 -540
  65. data/node_modules/@types/node/repl.d.ts +0 -430
  66. data/node_modules/@types/node/sea.d.ts +0 -153
  67. data/node_modules/@types/node/sqlite.d.ts +0 -213
  68. data/node_modules/@types/node/stream/consumers.d.ts +0 -12
  69. data/node_modules/@types/node/stream/promises.d.ts +0 -83
  70. data/node_modules/@types/node/stream/web.d.ts +0 -606
  71. data/node_modules/@types/node/stream.d.ts +0 -1726
  72. data/node_modules/@types/node/string_decoder.d.ts +0 -67
  73. data/node_modules/@types/node/test.d.ts +0 -2098
  74. data/node_modules/@types/node/timers/promises.d.ts +0 -97
  75. data/node_modules/@types/node/timers.d.ts +0 -240
  76. data/node_modules/@types/node/tls.d.ts +0 -1220
  77. data/node_modules/@types/node/trace_events.d.ts +0 -197
  78. data/node_modules/@types/node/tty.d.ts +0 -208
  79. data/node_modules/@types/node/url.d.ts +0 -969
  80. data/node_modules/@types/node/util.d.ts +0 -2301
  81. data/node_modules/@types/node/v8.d.ts +0 -808
  82. data/node_modules/@types/node/vm.d.ts +0 -922
  83. data/node_modules/@types/node/wasi.d.ts +0 -181
  84. data/node_modules/@types/node/worker_threads.d.ts +0 -712
  85. data/node_modules/@types/node/zlib.d.ts +0 -539
  86. data/node_modules/fsevents/LICENSE +0 -22
  87. data/node_modules/fsevents/README.md +0 -83
  88. data/node_modules/fsevents/fsevents.d.ts +0 -46
  89. data/node_modules/fsevents/fsevents.js +0 -82
  90. data/node_modules/fsevents/fsevents.node +0 -0
  91. data/node_modules/fsevents/package.json +0 -62
  92. data/node_modules/playwright/.eslintrc.js +0 -6
  93. data/node_modules/playwright/LICENSE +0 -202
  94. data/node_modules/playwright/NOTICE +0 -5
  95. data/node_modules/playwright/README.md +0 -169
  96. data/node_modules/playwright/ThirdPartyNotices.txt +0 -4356
  97. data/node_modules/playwright/cli.js +0 -19
  98. data/node_modules/playwright/index.d.ts +0 -17
  99. data/node_modules/playwright/index.js +0 -17
  100. data/node_modules/playwright/index.mjs +0 -18
  101. data/node_modules/playwright/jsx-runtime.js +0 -41
  102. data/node_modules/playwright/jsx-runtime.mjs +0 -21
  103. data/node_modules/playwright/lib/common/config.js +0 -256
  104. data/node_modules/playwright/lib/common/configLoader.js +0 -321
  105. data/node_modules/playwright/lib/common/esmLoaderHost.js +0 -93
  106. data/node_modules/playwright/lib/common/expectBundle.js +0 -27
  107. data/node_modules/playwright/lib/common/expectBundleImpl.js +0 -389
  108. data/node_modules/playwright/lib/common/fixtures.js +0 -323
  109. data/node_modules/playwright/lib/common/globals.js +0 -48
  110. data/node_modules/playwright/lib/common/ipc.js +0 -48
  111. data/node_modules/playwright/lib/common/poolBuilder.js +0 -79
  112. data/node_modules/playwright/lib/common/process.js +0 -140
  113. data/node_modules/playwright/lib/common/suiteUtils.js +0 -133
  114. data/node_modules/playwright/lib/common/test.js +0 -311
  115. data/node_modules/playwright/lib/common/testLoader.js +0 -102
  116. data/node_modules/playwright/lib/common/testType.js +0 -284
  117. data/node_modules/playwright/lib/fsWatcher.js +0 -69
  118. data/node_modules/playwright/lib/index.js +0 -888
  119. data/node_modules/playwright/lib/internalsForTest.js +0 -28
  120. data/node_modules/playwright/lib/isomorphic/events.js +0 -72
  121. data/node_modules/playwright/lib/isomorphic/folders.js +0 -25
  122. data/node_modules/playwright/lib/isomorphic/stringInternPool.js +0 -58
  123. data/node_modules/playwright/lib/isomorphic/teleReceiver.js +0 -504
  124. data/node_modules/playwright/lib/isomorphic/teleSuiteUpdater.js +0 -149
  125. data/node_modules/playwright/lib/isomorphic/testServerConnection.js +0 -210
  126. data/node_modules/playwright/lib/isomorphic/testServerInterface.js +0 -5
  127. data/node_modules/playwright/lib/isomorphic/testTree.js +0 -272
  128. data/node_modules/playwright/lib/loader/loaderMain.js +0 -58
  129. data/node_modules/playwright/lib/matchers/expect.js +0 -297
  130. data/node_modules/playwright/lib/matchers/matcherHint.js +0 -50
  131. data/node_modules/playwright/lib/matchers/matchers.js +0 -449
  132. data/node_modules/playwright/lib/matchers/toBeTruthy.js +0 -55
  133. data/node_modules/playwright/lib/matchers/toEqual.js +0 -57
  134. data/node_modules/playwright/lib/matchers/toMatchSnapshot.js +0 -383
  135. data/node_modules/playwright/lib/matchers/toMatchText.js +0 -76
  136. data/node_modules/playwright/lib/plugins/gitCommitInfoPlugin.js +0 -78
  137. data/node_modules/playwright/lib/plugins/index.js +0 -19
  138. data/node_modules/playwright/lib/plugins/webServerPlugin.js +0 -187
  139. data/node_modules/playwright/lib/program.js +0 -346
  140. data/node_modules/playwright/lib/reporters/base.js +0 -553
  141. data/node_modules/playwright/lib/reporters/blob.js +0 -133
  142. data/node_modules/playwright/lib/reporters/dot.js +0 -82
  143. data/node_modules/playwright/lib/reporters/empty.js +0 -42
  144. data/node_modules/playwright/lib/reporters/github.js +0 -115
  145. data/node_modules/playwright/lib/reporters/html.js +0 -623
  146. data/node_modules/playwright/lib/reporters/internalReporter.js +0 -123
  147. data/node_modules/playwright/lib/reporters/json.js +0 -243
  148. data/node_modules/playwright/lib/reporters/junit.js +0 -233
  149. data/node_modules/playwright/lib/reporters/line.js +0 -108
  150. data/node_modules/playwright/lib/reporters/list.js +0 -222
  151. data/node_modules/playwright/lib/reporters/markdown.js +0 -76
  152. data/node_modules/playwright/lib/reporters/merge.js +0 -477
  153. data/node_modules/playwright/lib/reporters/multiplexer.js +0 -90
  154. data/node_modules/playwright/lib/reporters/reporterV2.js +0 -118
  155. data/node_modules/playwright/lib/reporters/teleEmitter.js +0 -268
  156. data/node_modules/playwright/lib/reporters/versions/blobV1.js +0 -5
  157. data/node_modules/playwright/lib/runner/dispatcher.js +0 -532
  158. data/node_modules/playwright/lib/runner/failureTracker.js +0 -60
  159. data/node_modules/playwright/lib/runner/loadUtils.js +0 -308
  160. data/node_modules/playwright/lib/runner/loaderHost.js +0 -85
  161. data/node_modules/playwright/lib/runner/processHost.js +0 -175
  162. data/node_modules/playwright/lib/runner/projectUtils.js +0 -203
  163. data/node_modules/playwright/lib/runner/reporters.js +0 -151
  164. data/node_modules/playwright/lib/runner/runner.js +0 -179
  165. data/node_modules/playwright/lib/runner/sigIntWatcher.js +0 -100
  166. data/node_modules/playwright/lib/runner/taskRunner.js +0 -147
  167. data/node_modules/playwright/lib/runner/tasks.js +0 -407
  168. data/node_modules/playwright/lib/runner/testGroups.js +0 -136
  169. data/node_modules/playwright/lib/runner/testServer.js +0 -605
  170. data/node_modules/playwright/lib/runner/uiModeReporter.js +0 -31
  171. data/node_modules/playwright/lib/runner/vcs.js +0 -55
  172. data/node_modules/playwright/lib/runner/watchMode.js +0 -398
  173. data/node_modules/playwright/lib/runner/workerHost.js +0 -85
  174. data/node_modules/playwright/lib/third_party/tsconfig-loader.js +0 -134
  175. data/node_modules/playwright/lib/transform/babelBundle.js +0 -28
  176. data/node_modules/playwright/lib/transform/babelBundleImpl.js +0 -2032
  177. data/node_modules/playwright/lib/transform/compilationCache.js +0 -254
  178. data/node_modules/playwright/lib/transform/esmLoader.js +0 -117
  179. data/node_modules/playwright/lib/transform/esmUtils.js +0 -32
  180. data/node_modules/playwright/lib/transform/portTransport.js +0 -81
  181. data/node_modules/playwright/lib/transform/transform.js +0 -267
  182. data/node_modules/playwright/lib/util.js +0 -356
  183. data/node_modules/playwright/lib/utilsBundle.js +0 -28
  184. data/node_modules/playwright/lib/utilsBundleImpl.js +0 -102
  185. data/node_modules/playwright/lib/worker/fixtureRunner.js +0 -279
  186. data/node_modules/playwright/lib/worker/testInfo.js +0 -397
  187. data/node_modules/playwright/lib/worker/testTracing.js +0 -314
  188. data/node_modules/playwright/lib/worker/timeoutManager.js +0 -153
  189. data/node_modules/playwright/lib/worker/workerMain.js +0 -637
  190. data/node_modules/playwright/node_modules/.bin/playwright-core +0 -1
  191. data/node_modules/playwright/package.json +0 -66
  192. data/node_modules/playwright/test.d.ts +0 -18
  193. data/node_modules/playwright/test.js +0 -24
  194. data/node_modules/playwright/test.mjs +0 -33
  195. data/node_modules/playwright/types/test.d.ts +0 -8444
  196. data/node_modules/playwright/types/testReporter.d.ts +0 -749
  197. data/node_modules/playwright-core/LICENSE +0 -202
  198. data/node_modules/playwright-core/NOTICE +0 -5
  199. data/node_modules/playwright-core/README.md +0 -3
  200. data/node_modules/playwright-core/ThirdPartyNotices.txt +0 -1548
  201. data/node_modules/playwright-core/bin/PrintDeps.exe +0 -0
  202. data/node_modules/playwright-core/bin/README.md +0 -2
  203. data/node_modules/playwright-core/bin/install_media_pack.ps1 +0 -5
  204. data/node_modules/playwright-core/bin/reinstall_chrome_beta_linux.sh +0 -40
  205. data/node_modules/playwright-core/bin/reinstall_chrome_beta_mac.sh +0 -13
  206. data/node_modules/playwright-core/bin/reinstall_chrome_beta_win.ps1 +0 -24
  207. data/node_modules/playwright-core/bin/reinstall_chrome_stable_linux.sh +0 -40
  208. data/node_modules/playwright-core/bin/reinstall_chrome_stable_mac.sh +0 -12
  209. data/node_modules/playwright-core/bin/reinstall_chrome_stable_win.ps1 +0 -24
  210. data/node_modules/playwright-core/bin/reinstall_msedge_beta_linux.sh +0 -40
  211. data/node_modules/playwright-core/bin/reinstall_msedge_beta_mac.sh +0 -11
  212. data/node_modules/playwright-core/bin/reinstall_msedge_beta_win.ps1 +0 -23
  213. data/node_modules/playwright-core/bin/reinstall_msedge_dev_linux.sh +0 -40
  214. data/node_modules/playwright-core/bin/reinstall_msedge_dev_mac.sh +0 -11
  215. data/node_modules/playwright-core/bin/reinstall_msedge_dev_win.ps1 +0 -23
  216. data/node_modules/playwright-core/bin/reinstall_msedge_stable_linux.sh +0 -40
  217. data/node_modules/playwright-core/bin/reinstall_msedge_stable_mac.sh +0 -11
  218. data/node_modules/playwright-core/bin/reinstall_msedge_stable_win.ps1 +0 -24
  219. data/node_modules/playwright-core/browsers.json +0 -53
  220. data/node_modules/playwright-core/cli.js +0 -18
  221. data/node_modules/playwright-core/index.d.ts +0 -17
  222. data/node_modules/playwright-core/index.js +0 -33
  223. data/node_modules/playwright-core/index.mjs +0 -28
  224. data/node_modules/playwright-core/lib/androidServerImpl.js +0 -69
  225. data/node_modules/playwright-core/lib/browserServerImpl.js +0 -92
  226. data/node_modules/playwright-core/lib/cli/driver.js +0 -95
  227. data/node_modules/playwright-core/lib/cli/program.js +0 -577
  228. data/node_modules/playwright-core/lib/cli/programWithTestStub.js +0 -67
  229. data/node_modules/playwright-core/lib/client/accessibility.js +0 -50
  230. data/node_modules/playwright-core/lib/client/android.js +0 -473
  231. data/node_modules/playwright-core/lib/client/api.js +0 -279
  232. data/node_modules/playwright-core/lib/client/artifact.js +0 -79
  233. data/node_modules/playwright-core/lib/client/browser.js +0 -145
  234. data/node_modules/playwright-core/lib/client/browserContext.js +0 -541
  235. data/node_modules/playwright-core/lib/client/browserType.js +0 -241
  236. data/node_modules/playwright-core/lib/client/cdpSession.js +0 -53
  237. data/node_modules/playwright-core/lib/client/channelOwner.js +0 -231
  238. data/node_modules/playwright-core/lib/client/clientHelper.js +0 -57
  239. data/node_modules/playwright-core/lib/client/clientInstrumentation.js +0 -50
  240. data/node_modules/playwright-core/lib/client/clock.js +0 -68
  241. data/node_modules/playwright-core/lib/client/connection.js +0 -330
  242. data/node_modules/playwright-core/lib/client/consoleMessage.js +0 -55
  243. data/node_modules/playwright-core/lib/client/coverage.js +0 -41
  244. data/node_modules/playwright-core/lib/client/dialog.js +0 -57
  245. data/node_modules/playwright-core/lib/client/download.js +0 -62
  246. data/node_modules/playwright-core/lib/client/electron.js +0 -135
  247. data/node_modules/playwright-core/lib/client/elementHandle.js +0 -321
  248. data/node_modules/playwright-core/lib/client/errors.js +0 -77
  249. data/node_modules/playwright-core/lib/client/eventEmitter.js +0 -314
  250. data/node_modules/playwright-core/lib/client/events.js +0 -94
  251. data/node_modules/playwright-core/lib/client/fetch.js +0 -396
  252. data/node_modules/playwright-core/lib/client/fileChooser.js +0 -45
  253. data/node_modules/playwright-core/lib/client/frame.js +0 -504
  254. data/node_modules/playwright-core/lib/client/harRouter.js +0 -99
  255. data/node_modules/playwright-core/lib/client/input.js +0 -111
  256. data/node_modules/playwright-core/lib/client/jsHandle.js +0 -129
  257. data/node_modules/playwright-core/lib/client/jsonPipe.js +0 -35
  258. data/node_modules/playwright-core/lib/client/localUtils.js +0 -35
  259. data/node_modules/playwright-core/lib/client/locator.js +0 -441
  260. data/node_modules/playwright-core/lib/client/network.js +0 -604
  261. data/node_modules/playwright-core/lib/client/page.js +0 -725
  262. data/node_modules/playwright-core/lib/client/playwright.js +0 -77
  263. data/node_modules/playwright-core/lib/client/selectors.js +0 -67
  264. data/node_modules/playwright-core/lib/client/stream.js +0 -54
  265. data/node_modules/playwright-core/lib/client/tracing.js +0 -138
  266. data/node_modules/playwright-core/lib/client/types.js +0 -24
  267. data/node_modules/playwright-core/lib/client/video.js +0 -51
  268. data/node_modules/playwright-core/lib/client/waiter.js +0 -158
  269. data/node_modules/playwright-core/lib/client/webError.js +0 -37
  270. data/node_modules/playwright-core/lib/client/worker.js +0 -71
  271. data/node_modules/playwright-core/lib/client/writableStream.js +0 -54
  272. data/node_modules/playwright-core/lib/common/socksProxy.js +0 -569
  273. data/node_modules/playwright-core/lib/common/timeoutSettings.js +0 -73
  274. data/node_modules/playwright-core/lib/common/types.js +0 -5
  275. data/node_modules/playwright-core/lib/generated/clockSource.js +0 -7
  276. data/node_modules/playwright-core/lib/generated/consoleApiSource.js +0 -7
  277. data/node_modules/playwright-core/lib/generated/injectedScriptSource.js +0 -7
  278. data/node_modules/playwright-core/lib/generated/recorderSource.js +0 -7
  279. data/node_modules/playwright-core/lib/generated/utilityScriptSource.js +0 -7
  280. data/node_modules/playwright-core/lib/image_tools/colorUtils.js +0 -98
  281. data/node_modules/playwright-core/lib/image_tools/compare.js +0 -108
  282. data/node_modules/playwright-core/lib/image_tools/imageChannel.js +0 -70
  283. data/node_modules/playwright-core/lib/image_tools/stats.js +0 -102
  284. data/node_modules/playwright-core/lib/inProcessFactory.js +0 -54
  285. data/node_modules/playwright-core/lib/inprocess.js +0 -20
  286. data/node_modules/playwright-core/lib/outofprocess.js +0 -67
  287. data/node_modules/playwright-core/lib/protocol/debug.js +0 -27
  288. data/node_modules/playwright-core/lib/protocol/serializers.js +0 -173
  289. data/node_modules/playwright-core/lib/protocol/transport.js +0 -82
  290. data/node_modules/playwright-core/lib/protocol/validator.js +0 -2694
  291. data/node_modules/playwright-core/lib/protocol/validatorPrimitives.js +0 -139
  292. data/node_modules/playwright-core/lib/remote/playwrightConnection.js +0 -274
  293. data/node_modules/playwright-core/lib/remote/playwrightServer.js +0 -110
  294. data/node_modules/playwright-core/lib/server/accessibility.js +0 -62
  295. data/node_modules/playwright-core/lib/server/android/android.js +0 -441
  296. data/node_modules/playwright-core/lib/server/android/backendAdb.js +0 -172
  297. data/node_modules/playwright-core/lib/server/artifact.js +0 -104
  298. data/node_modules/playwright-core/lib/server/bidi/bidiBrowser.js +0 -296
  299. data/node_modules/playwright-core/lib/server/bidi/bidiConnection.js +0 -206
  300. data/node_modules/playwright-core/lib/server/bidi/bidiExecutionContext.js +0 -162
  301. data/node_modules/playwright-core/lib/server/bidi/bidiFirefox.js +0 -110
  302. data/node_modules/playwright-core/lib/server/bidi/bidiInput.js +0 -174
  303. data/node_modules/playwright-core/lib/server/bidi/bidiNetworkManager.js +0 -304
  304. data/node_modules/playwright-core/lib/server/bidi/bidiPage.js +0 -456
  305. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiDeserializer.js +0 -93
  306. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiKeyboard.js +0 -238
  307. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiProtocol.js +0 -139
  308. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiSerializer.js +0 -144
  309. data/node_modules/playwright-core/lib/server/browser.js +0 -137
  310. data/node_modules/playwright-core/lib/server/browserContext.js +0 -684
  311. data/node_modules/playwright-core/lib/server/browserType.js +0 -307
  312. data/node_modules/playwright-core/lib/server/chromium/appIcon.png +0 -0
  313. data/node_modules/playwright-core/lib/server/chromium/chromium.js +0 -362
  314. data/node_modules/playwright-core/lib/server/chromium/chromiumSwitches.js +0 -44
  315. data/node_modules/playwright-core/lib/server/chromium/crAccessibility.js +0 -237
  316. data/node_modules/playwright-core/lib/server/chromium/crBrowser.js +0 -515
  317. data/node_modules/playwright-core/lib/server/chromium/crConnection.js +0 -228
  318. data/node_modules/playwright-core/lib/server/chromium/crCoverage.js +0 -246
  319. data/node_modules/playwright-core/lib/server/chromium/crDevTools.js +0 -104
  320. data/node_modules/playwright-core/lib/server/chromium/crDragDrop.js +0 -143
  321. data/node_modules/playwright-core/lib/server/chromium/crExecutionContext.js +0 -156
  322. data/node_modules/playwright-core/lib/server/chromium/crInput.js +0 -171
  323. data/node_modules/playwright-core/lib/server/chromium/crNetworkManager.js +0 -767
  324. data/node_modules/playwright-core/lib/server/chromium/crPage.js +0 -1128
  325. data/node_modules/playwright-core/lib/server/chromium/crPdf.js +0 -153
  326. data/node_modules/playwright-core/lib/server/chromium/crProtocolHelper.js +0 -133
  327. data/node_modules/playwright-core/lib/server/chromium/crServiceWorker.js +0 -112
  328. data/node_modules/playwright-core/lib/server/chromium/defaultFontFamilies.js +0 -145
  329. data/node_modules/playwright-core/lib/server/chromium/videoRecorder.js +0 -155
  330. data/node_modules/playwright-core/lib/server/clock.js +0 -125
  331. data/node_modules/playwright-core/lib/server/codegen/csharp.js +0 -299
  332. data/node_modules/playwright-core/lib/server/codegen/java.js +0 -235
  333. data/node_modules/playwright-core/lib/server/codegen/javascript.js +0 -223
  334. data/node_modules/playwright-core/lib/server/codegen/jsonl.js +0 -47
  335. data/node_modules/playwright-core/lib/server/codegen/language.js +0 -76
  336. data/node_modules/playwright-core/lib/server/codegen/languages.js +0 -30
  337. data/node_modules/playwright-core/lib/server/codegen/python.js +0 -265
  338. data/node_modules/playwright-core/lib/server/codegen/types.js +0 -5
  339. data/node_modules/playwright-core/lib/server/console.js +0 -57
  340. data/node_modules/playwright-core/lib/server/cookieStore.js +0 -112
  341. data/node_modules/playwright-core/lib/server/debugController.js +0 -234
  342. data/node_modules/playwright-core/lib/server/debugger.js +0 -132
  343. data/node_modules/playwright-core/lib/server/deviceDescriptors.js +0 -26
  344. data/node_modules/playwright-core/lib/server/deviceDescriptorsSource.json +0 -1669
  345. data/node_modules/playwright-core/lib/server/dialog.js +0 -70
  346. data/node_modules/playwright-core/lib/server/dispatchers/androidDispatcher.js +0 -193
  347. data/node_modules/playwright-core/lib/server/dispatchers/artifactDispatcher.js +0 -118
  348. data/node_modules/playwright-core/lib/server/dispatchers/browserContextDispatcher.js +0 -351
  349. data/node_modules/playwright-core/lib/server/dispatchers/browserDispatcher.js +0 -170
  350. data/node_modules/playwright-core/lib/server/dispatchers/browserTypeDispatcher.js +0 -55
  351. data/node_modules/playwright-core/lib/server/dispatchers/cdpSessionDispatcher.js +0 -48
  352. data/node_modules/playwright-core/lib/server/dispatchers/debugControllerDispatcher.js +0 -103
  353. data/node_modules/playwright-core/lib/server/dispatchers/dialogDispatcher.js +0 -44
  354. data/node_modules/playwright-core/lib/server/dispatchers/dispatcher.js +0 -395
  355. data/node_modules/playwright-core/lib/server/dispatchers/electronDispatcher.js +0 -93
  356. data/node_modules/playwright-core/lib/server/dispatchers/elementHandlerDispatcher.js +0 -228
  357. data/node_modules/playwright-core/lib/server/dispatchers/frameDispatcher.js +0 -286
  358. data/node_modules/playwright-core/lib/server/dispatchers/jsHandleDispatcher.js +0 -102
  359. data/node_modules/playwright-core/lib/server/dispatchers/jsonPipeDispatcher.js +0 -59
  360. data/node_modules/playwright-core/lib/server/dispatchers/localUtilsDispatcher.js +0 -413
  361. data/node_modules/playwright-core/lib/server/dispatchers/networkDispatchers.js +0 -221
  362. data/node_modules/playwright-core/lib/server/dispatchers/pageDispatcher.js +0 -358
  363. data/node_modules/playwright-core/lib/server/dispatchers/playwrightDispatcher.js +0 -106
  364. data/node_modules/playwright-core/lib/server/dispatchers/selectorsDispatcher.js +0 -36
  365. data/node_modules/playwright-core/lib/server/dispatchers/streamDispatcher.js +0 -62
  366. data/node_modules/playwright-core/lib/server/dispatchers/tracingDispatcher.js +0 -54
  367. data/node_modules/playwright-core/lib/server/dispatchers/writableStreamDispatcher.js +0 -58
  368. data/node_modules/playwright-core/lib/server/dom.js +0 -845
  369. data/node_modules/playwright-core/lib/server/download.js +0 -53
  370. data/node_modules/playwright-core/lib/server/electron/electron.js +0 -296
  371. data/node_modules/playwright-core/lib/server/electron/loader.js +0 -57
  372. data/node_modules/playwright-core/lib/server/errors.js +0 -68
  373. data/node_modules/playwright-core/lib/server/fetch.js +0 -660
  374. data/node_modules/playwright-core/lib/server/fileChooser.js +0 -42
  375. data/node_modules/playwright-core/lib/server/fileUploadUtils.js +0 -75
  376. data/node_modules/playwright-core/lib/server/firefox/ffAccessibility.js +0 -216
  377. data/node_modules/playwright-core/lib/server/firefox/ffBrowser.js +0 -458
  378. data/node_modules/playwright-core/lib/server/firefox/ffConnection.js +0 -168
  379. data/node_modules/playwright-core/lib/server/firefox/ffExecutionContext.js +0 -138
  380. data/node_modules/playwright-core/lib/server/firefox/ffInput.js +0 -150
  381. data/node_modules/playwright-core/lib/server/firefox/ffNetworkManager.js +0 -233
  382. data/node_modules/playwright-core/lib/server/firefox/ffPage.js +0 -556
  383. data/node_modules/playwright-core/lib/server/firefox/firefox.js +0 -110
  384. data/node_modules/playwright-core/lib/server/formData.js +0 -75
  385. data/node_modules/playwright-core/lib/server/frameSelectors.js +0 -171
  386. data/node_modules/playwright-core/lib/server/frames.js +0 -1654
  387. data/node_modules/playwright-core/lib/server/har/harRecorder.js +0 -139
  388. data/node_modules/playwright-core/lib/server/har/harTracer.js +0 -531
  389. data/node_modules/playwright-core/lib/server/helper.js +0 -103
  390. data/node_modules/playwright-core/lib/server/index.js +0 -114
  391. data/node_modules/playwright-core/lib/server/input.js +0 -311
  392. data/node_modules/playwright-core/lib/server/instrumentation.js +0 -70
  393. data/node_modules/playwright-core/lib/server/isomorphic/utilityScriptSerializers.js +0 -226
  394. data/node_modules/playwright-core/lib/server/javascript.js +0 -306
  395. data/node_modules/playwright-core/lib/server/launchApp.js +0 -91
  396. data/node_modules/playwright-core/lib/server/macEditingCommands.js +0 -139
  397. data/node_modules/playwright-core/lib/server/network.js +0 -617
  398. data/node_modules/playwright-core/lib/server/page.js +0 -825
  399. data/node_modules/playwright-core/lib/server/pipeTransport.js +0 -85
  400. data/node_modules/playwright-core/lib/server/playwright.js +0 -85
  401. data/node_modules/playwright-core/lib/server/progress.js +0 -102
  402. data/node_modules/playwright-core/lib/server/protocolError.js +0 -49
  403. data/node_modules/playwright-core/lib/server/recorder/contextRecorder.js +0 -316
  404. data/node_modules/playwright-core/lib/server/recorder/recorderActions.js +0 -5
  405. data/node_modules/playwright-core/lib/server/recorder/recorderApp.js +0 -190
  406. data/node_modules/playwright-core/lib/server/recorder/recorderCollection.js +0 -127
  407. data/node_modules/playwright-core/lib/server/recorder/recorderRunner.js +0 -177
  408. data/node_modules/playwright-core/lib/server/recorder/recorderUtils.js +0 -71
  409. data/node_modules/playwright-core/lib/server/recorder/throttledFile.js +0 -46
  410. data/node_modules/playwright-core/lib/server/recorder.js +0 -324
  411. data/node_modules/playwright-core/lib/server/registry/browserFetcher.js +0 -168
  412. data/node_modules/playwright-core/lib/server/registry/dependencies.js +0 -322
  413. data/node_modules/playwright-core/lib/server/registry/index.js +0 -924
  414. data/node_modules/playwright-core/lib/server/registry/nativeDeps.js +0 -490
  415. data/node_modules/playwright-core/lib/server/registry/oopDownloadBrowserMain.js +0 -138
  416. data/node_modules/playwright-core/lib/server/screenshotter.js +0 -348
  417. data/node_modules/playwright-core/lib/server/selectors.js +0 -73
  418. data/node_modules/playwright-core/lib/server/socksClientCertificatesInterceptor.js +0 -328
  419. data/node_modules/playwright-core/lib/server/socksInterceptor.js +0 -100
  420. data/node_modules/playwright-core/lib/server/trace/recorder/snapshotter.js +0 -171
  421. data/node_modules/playwright-core/lib/server/trace/recorder/snapshotterInjected.js +0 -493
  422. data/node_modules/playwright-core/lib/server/trace/recorder/tracing.js +0 -486
  423. data/node_modules/playwright-core/lib/server/trace/test/inMemorySnapshotter.js +0 -93
  424. data/node_modules/playwright-core/lib/server/trace/viewer/traceViewer.js +0 -216
  425. data/node_modules/playwright-core/lib/server/transport.js +0 -191
  426. data/node_modules/playwright-core/lib/server/types.js +0 -24
  427. data/node_modules/playwright-core/lib/server/usKeyboardLayout.js +0 -555
  428. data/node_modules/playwright-core/lib/server/webkit/webkit.js +0 -87
  429. data/node_modules/playwright-core/lib/server/webkit/wkAccessibility.js +0 -194
  430. data/node_modules/playwright-core/lib/server/webkit/wkBrowser.js +0 -328
  431. data/node_modules/playwright-core/lib/server/webkit/wkConnection.js +0 -173
  432. data/node_modules/playwright-core/lib/server/webkit/wkExecutionContext.js +0 -146
  433. data/node_modules/playwright-core/lib/server/webkit/wkInput.js +0 -169
  434. data/node_modules/playwright-core/lib/server/webkit/wkInterceptableRequest.js +0 -162
  435. data/node_modules/playwright-core/lib/server/webkit/wkPage.js +0 -1216
  436. data/node_modules/playwright-core/lib/server/webkit/wkProvisionalPage.js +0 -94
  437. data/node_modules/playwright-core/lib/server/webkit/wkWorkers.js +0 -104
  438. data/node_modules/playwright-core/lib/third_party/diff_match_patch.js +0 -2222
  439. data/node_modules/playwright-core/lib/third_party/pixelmatch.js +0 -255
  440. data/node_modules/playwright-core/lib/utils/ascii.js +0 -31
  441. data/node_modules/playwright-core/lib/utils/comparators.js +0 -171
  442. data/node_modules/playwright-core/lib/utils/crypto.js +0 -174
  443. data/node_modules/playwright-core/lib/utils/debug.js +0 -46
  444. data/node_modules/playwright-core/lib/utils/debugLogger.js +0 -91
  445. data/node_modules/playwright-core/lib/utils/env.js +0 -49
  446. data/node_modules/playwright-core/lib/utils/eventsHelper.js +0 -38
  447. data/node_modules/playwright-core/lib/utils/expectUtils.js +0 -33
  448. data/node_modules/playwright-core/lib/utils/fileUtils.js +0 -205
  449. data/node_modules/playwright-core/lib/utils/happy-eyeballs.js +0 -181
  450. data/node_modules/playwright-core/lib/utils/headers.js +0 -52
  451. data/node_modules/playwright-core/lib/utils/hostPlatform.js +0 -133
  452. data/node_modules/playwright-core/lib/utils/httpServer.js +0 -236
  453. data/node_modules/playwright-core/lib/utils/index.js +0 -368
  454. data/node_modules/playwright-core/lib/utils/isomorphic/cssParser.js +0 -250
  455. data/node_modules/playwright-core/lib/utils/isomorphic/cssTokenizer.js +0 -979
  456. data/node_modules/playwright-core/lib/utils/isomorphic/locatorGenerators.js +0 -651
  457. data/node_modules/playwright-core/lib/utils/isomorphic/locatorParser.js +0 -179
  458. data/node_modules/playwright-core/lib/utils/isomorphic/locatorUtils.js +0 -62
  459. data/node_modules/playwright-core/lib/utils/isomorphic/mimeType.js +0 -29
  460. data/node_modules/playwright-core/lib/utils/isomorphic/selectorParser.js +0 -397
  461. data/node_modules/playwright-core/lib/utils/isomorphic/stringUtils.js +0 -139
  462. data/node_modules/playwright-core/lib/utils/isomorphic/traceUtils.js +0 -39
  463. data/node_modules/playwright-core/lib/utils/isomorphic/urlMatch.js +0 -120
  464. data/node_modules/playwright-core/lib/utils/linuxUtils.js +0 -78
  465. data/node_modules/playwright-core/lib/utils/manualPromise.js +0 -109
  466. data/node_modules/playwright-core/lib/utils/multimap.js +0 -75
  467. data/node_modules/playwright-core/lib/utils/network.js +0 -160
  468. data/node_modules/playwright-core/lib/utils/processLauncher.js +0 -248
  469. data/node_modules/playwright-core/lib/utils/profiler.js +0 -53
  470. data/node_modules/playwright-core/lib/utils/rtti.js +0 -44
  471. data/node_modules/playwright-core/lib/utils/semaphore.js +0 -51
  472. data/node_modules/playwright-core/lib/utils/spawnAsync.js +0 -45
  473. data/node_modules/playwright-core/lib/utils/stackTrace.js +0 -121
  474. data/node_modules/playwright-core/lib/utils/task.js +0 -58
  475. data/node_modules/playwright-core/lib/utils/time.js +0 -37
  476. data/node_modules/playwright-core/lib/utils/timeoutRunner.js +0 -66
  477. data/node_modules/playwright-core/lib/utils/traceUtils.js +0 -44
  478. data/node_modules/playwright-core/lib/utils/userAgent.js +0 -105
  479. data/node_modules/playwright-core/lib/utils/wsServer.js +0 -127
  480. data/node_modules/playwright-core/lib/utils/zipFile.js +0 -75
  481. data/node_modules/playwright-core/lib/utils/zones.js +0 -62
  482. data/node_modules/playwright-core/lib/utilsBundle.js +0 -82
  483. data/node_modules/playwright-core/lib/utilsBundleImpl/index.js +0 -53
  484. data/node_modules/playwright-core/lib/utilsBundleImpl/xdg-open +0 -1066
  485. data/node_modules/playwright-core/lib/vite/htmlReport/index.html +0 -66
  486. data/node_modules/playwright-core/lib/vite/recorder/assets/codeMirrorModule-aW6Vz3gf.js +0 -24
  487. data/node_modules/playwright-core/lib/vite/recorder/assets/codeMirrorModule-ez37Vkbh.css +0 -1
  488. data/node_modules/playwright-core/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  489. data/node_modules/playwright-core/lib/vite/recorder/assets/index-B-MT5gKo.css +0 -1
  490. data/node_modules/playwright-core/lib/vite/recorder/assets/index-DCpXOVIh.js +0 -47
  491. data/node_modules/playwright-core/lib/vite/recorder/index.html +0 -29
  492. data/node_modules/playwright-core/lib/vite/recorder/playwright-logo.svg +0 -9
  493. data/node_modules/playwright-core/lib/vite/traceViewer/assets/codeMirrorModule-eFKCUIu2.js +0 -24
  494. data/node_modules/playwright-core/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +0 -1
  495. data/node_modules/playwright-core/lib/vite/traceViewer/assets/workbench-D0cirtfA.js +0 -72
  496. data/node_modules/playwright-core/lib/vite/traceViewer/assets/xtermModule-BeNbaIVa.js +0 -9
  497. data/node_modules/playwright-core/lib/vite/traceViewer/codeMirrorModule.ez37Vkbh.css +0 -1
  498. data/node_modules/playwright-core/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  499. data/node_modules/playwright-core/lib/vite/traceViewer/embedded.BkuvsLJp.js +0 -2
  500. data/node_modules/playwright-core/lib/vite/traceViewer/embedded.html +0 -16
  501. data/node_modules/playwright-core/lib/vite/traceViewer/embedded.w7WN2u1R.css +0 -1
  502. data/node_modules/playwright-core/lib/vite/traceViewer/index.C968kAiC.js +0 -2
  503. data/node_modules/playwright-core/lib/vite/traceViewer/index.CrbWWHbf.css +0 -1
  504. data/node_modules/playwright-core/lib/vite/traceViewer/index.html +0 -27
  505. data/node_modules/playwright-core/lib/vite/traceViewer/playwright-logo.svg +0 -9
  506. data/node_modules/playwright-core/lib/vite/traceViewer/snapshot.html +0 -21
  507. data/node_modules/playwright-core/lib/vite/traceViewer/sw.bundle.js +0 -3
  508. data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.BkFnr4V0.js +0 -10
  509. data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.D3cNFP6u.css +0 -1
  510. data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.html +0 -18
  511. data/node_modules/playwright-core/lib/vite/traceViewer/workbench.DjbIuxix.css +0 -1
  512. data/node_modules/playwright-core/lib/vite/traceViewer/xtermModule.DSXBckUd.css +0 -32
  513. data/node_modules/playwright-core/lib/zipBundle.js +0 -25
  514. data/node_modules/playwright-core/lib/zipBundleImpl.js +0 -5
  515. data/node_modules/playwright-core/package.json +0 -44
  516. data/node_modules/playwright-core/types/protocol.d.ts +0 -21500
  517. data/node_modules/playwright-core/types/structs.d.ts +0 -45
  518. data/node_modules/playwright-core/types/types.d.ts +0 -21431
  519. data/node_modules/undici-types/LICENSE +0 -21
  520. data/node_modules/undici-types/README.md +0 -6
  521. data/node_modules/undici-types/agent.d.ts +0 -31
  522. data/node_modules/undici-types/api.d.ts +0 -43
  523. data/node_modules/undici-types/balanced-pool.d.ts +0 -29
  524. data/node_modules/undici-types/cache.d.ts +0 -36
  525. data/node_modules/undici-types/client.d.ts +0 -108
  526. data/node_modules/undici-types/connector.d.ts +0 -34
  527. data/node_modules/undici-types/content-type.d.ts +0 -21
  528. data/node_modules/undici-types/cookies.d.ts +0 -28
  529. data/node_modules/undici-types/diagnostics-channel.d.ts +0 -66
  530. data/node_modules/undici-types/dispatcher.d.ts +0 -255
  531. data/node_modules/undici-types/env-http-proxy-agent.d.ts +0 -21
  532. data/node_modules/undici-types/errors.d.ts +0 -149
  533. data/node_modules/undici-types/eventsource.d.ts +0 -63
  534. data/node_modules/undici-types/fetch.d.ts +0 -209
  535. data/node_modules/undici-types/file.d.ts +0 -39
  536. data/node_modules/undici-types/filereader.d.ts +0 -54
  537. data/node_modules/undici-types/formdata.d.ts +0 -108
  538. data/node_modules/undici-types/global-dispatcher.d.ts +0 -9
  539. data/node_modules/undici-types/global-origin.d.ts +0 -7
  540. data/node_modules/undici-types/handlers.d.ts +0 -15
  541. data/node_modules/undici-types/header.d.ts +0 -4
  542. data/node_modules/undici-types/index.d.ts +0 -71
  543. data/node_modules/undici-types/interceptors.d.ts +0 -15
  544. data/node_modules/undici-types/mock-agent.d.ts +0 -50
  545. data/node_modules/undici-types/mock-client.d.ts +0 -25
  546. data/node_modules/undici-types/mock-errors.d.ts +0 -12
  547. data/node_modules/undici-types/mock-interceptor.d.ts +0 -93
  548. data/node_modules/undici-types/mock-pool.d.ts +0 -25
  549. data/node_modules/undici-types/package.json +0 -55
  550. data/node_modules/undici-types/patch.d.ts +0 -71
  551. data/node_modules/undici-types/pool-stats.d.ts +0 -19
  552. data/node_modules/undici-types/pool.d.ts +0 -39
  553. data/node_modules/undici-types/proxy-agent.d.ts +0 -28
  554. data/node_modules/undici-types/readable.d.ts +0 -60
  555. data/node_modules/undici-types/retry-agent.d.ts +0 -8
  556. data/node_modules/undici-types/retry-handler.d.ts +0 -116
  557. data/node_modules/undici-types/util.d.ts +0 -18
  558. data/node_modules/undici-types/webidl.d.ts +0 -222
  559. data/node_modules/undici-types/websocket.d.ts +0 -152
  560. data/yarn.lock +0 -41
@@ -1,845 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.NonRecoverableDOMError = exports.FrameExecutionContext = exports.ElementHandle = void 0;
7
- exports.assertDone = assertDone;
8
- exports.isNonRecoverableDOMError = isNonRecoverableDOMError;
9
- exports.kUnableToAdoptErrorMessage = void 0;
10
- exports.throwRetargetableDOMError = throwRetargetableDOMError;
11
- var _fs = _interopRequireDefault(require("fs"));
12
- var injectedScriptSource = _interopRequireWildcard(require("../generated/injectedScriptSource"));
13
- var _protocolError = require("./protocolError");
14
- var js = _interopRequireWildcard(require("./javascript"));
15
- var _progress = require("./progress");
16
- var _utils = require("../utils");
17
- var _fileUploadUtils = require("./fileUploadUtils");
18
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
19
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
20
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
- /**
22
- * Copyright (c) Microsoft Corporation.
23
- *
24
- * Licensed under the Apache License, Version 2.0 (the "License");
25
- * you may not use this file except in compliance with the License.
26
- * You may obtain a copy of the License at
27
- *
28
- * http://www.apache.org/licenses/LICENSE-2.0
29
- *
30
- * Unless required by applicable law or agreed to in writing, software
31
- * distributed under the License is distributed on an "AS IS" BASIS,
32
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
33
- * See the License for the specific language governing permissions and
34
- * limitations under the License.
35
- */
36
-
37
- class NonRecoverableDOMError extends Error {}
38
- exports.NonRecoverableDOMError = NonRecoverableDOMError;
39
- function isNonRecoverableDOMError(error) {
40
- return error instanceof NonRecoverableDOMError;
41
- }
42
- class FrameExecutionContext extends js.ExecutionContext {
43
- constructor(delegate, frame, world) {
44
- super(frame, delegate, world || 'content-script');
45
- this.frame = void 0;
46
- this._injectedScriptPromise = void 0;
47
- this.world = void 0;
48
- this.frame = frame;
49
- this.world = world;
50
- }
51
- adoptIfNeeded(handle) {
52
- if (handle instanceof ElementHandle && handle._context !== this) return this.frame._page._delegate.adoptElementHandle(handle, this);
53
- return null;
54
- }
55
- async evaluate(pageFunction, arg) {
56
- return js.evaluate(this, true /* returnByValue */, pageFunction, arg);
57
- }
58
- async evaluateHandle(pageFunction, arg) {
59
- return js.evaluate(this, false /* returnByValue */, pageFunction, arg);
60
- }
61
- async evaluateExpression(expression, options, arg) {
62
- return js.evaluateExpression(this, expression, {
63
- ...options,
64
- returnByValue: true
65
- }, arg);
66
- }
67
- async evaluateExpressionHandle(expression, options, arg) {
68
- return js.evaluateExpression(this, expression, {
69
- ...options,
70
- returnByValue: false
71
- }, arg);
72
- }
73
- createHandle(remoteObject) {
74
- if (this.frame._page._delegate.isElementHandle(remoteObject)) return new ElementHandle(this, remoteObject.objectId);
75
- return super.createHandle(remoteObject);
76
- }
77
- injectedScript() {
78
- if (!this._injectedScriptPromise) {
79
- const custom = [];
80
- const selectorsRegistry = this.frame._page.context().selectors();
81
- for (const [name, {
82
- source
83
- }] of selectorsRegistry._engines) custom.push(`{ name: '${name}', engine: (${source}) }`);
84
- const sdkLanguage = this.frame.attribution.playwright.options.sdkLanguage;
85
- const source = `
86
- (() => {
87
- const module = {};
88
- ${injectedScriptSource.source}
89
- return new (module.exports.InjectedScript())(
90
- globalThis,
91
- ${(0, _utils.isUnderTest)()},
92
- "${sdkLanguage}",
93
- ${JSON.stringify(selectorsRegistry.testIdAttributeName())},
94
- ${this.frame._page._delegate.rafCountForStablePosition()},
95
- "${this.frame._page._browserContext._browser.options.name}",
96
- [${custom.join(',\n')}]
97
- );
98
- })();
99
- `;
100
- this._injectedScriptPromise = this.rawEvaluateHandle(source).then(objectId => new js.JSHandle(this, 'object', 'InjectedScript', objectId));
101
- }
102
- return this._injectedScriptPromise;
103
- }
104
- }
105
- exports.FrameExecutionContext = FrameExecutionContext;
106
- class ElementHandle extends js.JSHandle {
107
- constructor(context, objectId) {
108
- super(context, 'node', undefined, objectId);
109
- this.__elementhandle = true;
110
- this._page = void 0;
111
- this._frame = void 0;
112
- this._page = context.frame._page;
113
- this._frame = context.frame;
114
- this._initializePreview().catch(e => {});
115
- }
116
- async _initializePreview() {
117
- const utility = await this._context.injectedScript();
118
- this._setPreview(await utility.evaluate((injected, e) => 'JSHandle@' + injected.previewNode(e), this));
119
- }
120
- asElement() {
121
- return this;
122
- }
123
- async evaluateInUtility(pageFunction, arg) {
124
- try {
125
- const utility = await this._frame._utilityContext();
126
- return await utility.evaluate(pageFunction, [await utility.injectedScript(), this, arg]);
127
- } catch (e) {
128
- if (js.isJavaScriptErrorInEvaluate(e) || (0, _protocolError.isSessionClosedError)(e)) throw e;
129
- return 'error:notconnected';
130
- }
131
- }
132
- async evaluateHandleInUtility(pageFunction, arg) {
133
- try {
134
- const utility = await this._frame._utilityContext();
135
- return await utility.evaluateHandle(pageFunction, [await utility.injectedScript(), this, arg]);
136
- } catch (e) {
137
- if (js.isJavaScriptErrorInEvaluate(e) || (0, _protocolError.isSessionClosedError)(e)) throw e;
138
- return 'error:notconnected';
139
- }
140
- }
141
- async ownerFrame() {
142
- const frameId = await this._page._delegate.getOwnerFrame(this);
143
- if (!frameId) return null;
144
- const frame = this._page._frameManager.frame(frameId);
145
- if (frame) return frame;
146
- for (const page of this._page._browserContext.pages()) {
147
- const frame = page._frameManager.frame(frameId);
148
- if (frame) return frame;
149
- }
150
- return null;
151
- }
152
- async isIframeElement() {
153
- return this.evaluateInUtility(([injected, node]) => node && (node.nodeName === 'IFRAME' || node.nodeName === 'FRAME'), {});
154
- }
155
- async contentFrame() {
156
- const isFrameElement = throwRetargetableDOMError(await this.isIframeElement());
157
- if (!isFrameElement) return null;
158
- return this._page._delegate.getContentFrame(this);
159
- }
160
- async getAttribute(metadata, name) {
161
- return this._frame.getAttribute(metadata, ':scope', name, {}, this);
162
- }
163
- async inputValue(metadata) {
164
- return this._frame.inputValue(metadata, ':scope', {}, this);
165
- }
166
- async textContent(metadata) {
167
- return this._frame.textContent(metadata, ':scope', {}, this);
168
- }
169
- async innerText(metadata) {
170
- return this._frame.innerText(metadata, ':scope', {}, this);
171
- }
172
- async innerHTML(metadata) {
173
- return this._frame.innerHTML(metadata, ':scope', {}, this);
174
- }
175
- async dispatchEvent(metadata, type, eventInit = {}) {
176
- return this._frame.dispatchEvent(metadata, ':scope', type, eventInit, {}, this);
177
- }
178
- async _scrollRectIntoViewIfNeeded(rect) {
179
- return await this._page._delegate.scrollRectIntoViewIfNeeded(this, rect);
180
- }
181
- async _waitAndScrollIntoViewIfNeeded(progress, waitForVisible) {
182
- const result = await this._retryAction(progress, 'scroll into view', async () => {
183
- progress.log(` waiting for element to be stable`);
184
- const waitResult = await this.evaluateInUtility(async ([injected, node, {
185
- waitForVisible
186
- }]) => {
187
- return await injected.checkElementStates(node, waitForVisible ? ['visible', 'stable'] : ['stable']);
188
- }, {
189
- waitForVisible
190
- });
191
- if (waitResult) return waitResult;
192
- return await this._scrollRectIntoViewIfNeeded();
193
- }, {});
194
- assertDone(throwRetargetableDOMError(result));
195
- }
196
- async scrollIntoViewIfNeeded(metadata, options = {}) {
197
- const controller = new _progress.ProgressController(metadata, this);
198
- return controller.run(progress => this._waitAndScrollIntoViewIfNeeded(progress, false /* waitForVisible */), this._page._timeoutSettings.timeout(options));
199
- }
200
- async _clickablePoint() {
201
- const intersectQuadWithViewport = quad => {
202
- return quad.map(point => ({
203
- x: Math.min(Math.max(point.x, 0), metrics.width),
204
- y: Math.min(Math.max(point.y, 0), metrics.height)
205
- }));
206
- };
207
- const computeQuadArea = quad => {
208
- // Compute sum of all directed areas of adjacent triangles
209
- // https://en.wikipedia.org/wiki/Polygon#Simple_polygons
210
- let area = 0;
211
- for (let i = 0; i < quad.length; ++i) {
212
- const p1 = quad[i];
213
- const p2 = quad[(i + 1) % quad.length];
214
- area += (p1.x * p2.y - p2.x * p1.y) / 2;
215
- }
216
- return Math.abs(area);
217
- };
218
- const [quads, metrics] = await Promise.all([this._page._delegate.getContentQuads(this), this._page.mainFrame()._utilityContext().then(utility => utility.evaluate(() => ({
219
- width: innerWidth,
220
- height: innerHeight
221
- })))]);
222
- if (quads === 'error:notconnected') return quads;
223
- if (!quads || !quads.length) return 'error:notvisible';
224
-
225
- // Allow 1x1 elements. Compensate for rounding errors by comparing with 0.99 instead.
226
- const filtered = quads.map(quad => intersectQuadWithViewport(quad)).filter(quad => computeQuadArea(quad) > 0.99);
227
- if (!filtered.length) return 'error:notinviewport';
228
- // Return the middle point of the first quad.
229
- const result = {
230
- x: 0,
231
- y: 0
232
- };
233
- for (const point of filtered[0]) {
234
- result.x += point.x / 4;
235
- result.y += point.y / 4;
236
- }
237
- compensateHalfIntegerRoundingError(result);
238
- return result;
239
- }
240
- async _offsetPoint(offset) {
241
- const [box, border] = await Promise.all([this.boundingBox(), this.evaluateInUtility(([injected, node]) => injected.getElementBorderWidth(node), {}).catch(e => {})]);
242
- if (!box || !border) return 'error:notvisible';
243
- if (border === 'error:notconnected') return border;
244
- // Make point relative to the padding box to align with offsetX/offsetY.
245
- return {
246
- x: box.x + border.left + offset.x,
247
- y: box.y + border.top + offset.y
248
- };
249
- }
250
- async _retryAction(progress, actionName, action, options) {
251
- let retry = 0;
252
- // We progressively wait longer between retries, up to 500ms.
253
- const waitTime = [0, 20, 100, 100, 500];
254
- while (progress.isRunning()) {
255
- if (retry) {
256
- progress.log(`retrying ${actionName} action${options.trial ? ' (trial run)' : ''}, attempt #${retry}`);
257
- const timeout = waitTime[Math.min(retry - 1, waitTime.length - 1)];
258
- if (timeout) {
259
- progress.log(` waiting ${timeout}ms`);
260
- const result = await this.evaluateInUtility(([injected, node, timeout]) => new Promise(f => setTimeout(f, timeout)), timeout);
261
- if (result === 'error:notconnected') return result;
262
- }
263
- } else {
264
- progress.log(`attempting ${actionName} action${options.trial ? ' (trial run)' : ''}`);
265
- }
266
- if (!options.skipLocatorHandlersCheckpoint && !options.force) await this._frame._page.performLocatorHandlersCheckpoint(progress);
267
- const result = await action(retry);
268
- ++retry;
269
- if (result === 'error:notvisible') {
270
- if (options.force) throw new NonRecoverableDOMError('Element is not visible');
271
- progress.log(' element is not visible');
272
- continue;
273
- }
274
- if (result === 'error:notinviewport') {
275
- if (options.force) throw new NonRecoverableDOMError('Element is outside of the viewport');
276
- progress.log(' element is outside of the viewport');
277
- continue;
278
- }
279
- if (result === 'error:optionsnotfound') {
280
- progress.log(' did not find some options');
281
- continue;
282
- }
283
- if (typeof result === 'object' && 'hitTargetDescription' in result) {
284
- progress.log(` ${result.hitTargetDescription} intercepts pointer events`);
285
- continue;
286
- }
287
- if (typeof result === 'object' && 'missingState' in result) {
288
- progress.log(` element is not ${result.missingState}`);
289
- continue;
290
- }
291
- return result;
292
- }
293
- return 'done';
294
- }
295
- async _retryPointerAction(progress, actionName, waitForEnabled, action, options) {
296
- // Note: do not perform locator handlers checkpoint to avoid moving the mouse in the middle of a drag operation.
297
- const skipLocatorHandlersCheckpoint = actionName === 'move and up';
298
- return await this._retryAction(progress, actionName, async retry => {
299
- // By default, we scroll with protocol method to reveal the action point.
300
- // However, that might not work to scroll from under position:sticky elements
301
- // that overlay the target element. To fight this, we cycle through different
302
- // scroll alignments. This works in most scenarios.
303
- const scrollOptions = [undefined, {
304
- block: 'end',
305
- inline: 'end'
306
- }, {
307
- block: 'center',
308
- inline: 'center'
309
- }, {
310
- block: 'start',
311
- inline: 'start'
312
- }];
313
- const forceScrollOptions = scrollOptions[retry % scrollOptions.length];
314
- return await this._performPointerAction(progress, actionName, waitForEnabled, action, forceScrollOptions, options);
315
- }, {
316
- ...options,
317
- skipLocatorHandlersCheckpoint
318
- });
319
- }
320
- async _performPointerAction(progress, actionName, waitForEnabled, action, forceScrollOptions, options) {
321
- const {
322
- force = false,
323
- position
324
- } = options;
325
- const doScrollIntoView = async () => {
326
- if (forceScrollOptions) {
327
- return await this.evaluateInUtility(([injected, node, options]) => {
328
- if (node.nodeType === 1 /* Node.ELEMENT_NODE */) node.scrollIntoView(options);
329
- return 'done';
330
- }, forceScrollOptions);
331
- }
332
- return await this._scrollRectIntoViewIfNeeded(position ? {
333
- x: position.x,
334
- y: position.y,
335
- width: 0,
336
- height: 0
337
- } : undefined);
338
- };
339
- if (this._frame.parentFrame()) {
340
- // Best-effort scroll to make sure any iframes containing this element are scrolled
341
- // into view and visible, so they are not throttled.
342
- // See https://github.com/microsoft/playwright/issues/27196 for an example.
343
- progress.throwIfAborted(); // Avoid action that has side-effects.
344
- await doScrollIntoView().catch(() => {});
345
- }
346
- if (options.__testHookBeforeStable) await options.__testHookBeforeStable();
347
- if (!force) {
348
- const elementStates = waitForEnabled ? ['visible', 'enabled', 'stable'] : ['visible', 'stable'];
349
- progress.log(` waiting for element to be ${waitForEnabled ? 'visible, enabled and stable' : 'visible and stable'}`);
350
- const result = await this.evaluateInUtility(async ([injected, node, {
351
- elementStates
352
- }]) => {
353
- return await injected.checkElementStates(node, elementStates);
354
- }, {
355
- elementStates
356
- });
357
- if (result) return result;
358
- progress.log(` element is ${waitForEnabled ? 'visible, enabled and stable' : 'visible and stable'}`);
359
- }
360
- if (options.__testHookAfterStable) await options.__testHookAfterStable();
361
- progress.log(' scrolling into view if needed');
362
- progress.throwIfAborted(); // Avoid action that has side-effects.
363
- const scrolled = await doScrollIntoView();
364
- if (scrolled !== 'done') return scrolled;
365
- progress.log(' done scrolling');
366
- const maybePoint = position ? await this._offsetPoint(position) : await this._clickablePoint();
367
- if (typeof maybePoint === 'string') return maybePoint;
368
- const point = roundPoint(maybePoint);
369
- progress.metadata.point = point;
370
- await progress.beforeInputAction(this);
371
- let hitTargetInterceptionHandle;
372
- if (force) {
373
- progress.log(` forcing action`);
374
- } else {
375
- if (options.__testHookBeforeHitTarget) await options.__testHookBeforeHitTarget();
376
- const frameCheckResult = await this._checkFrameIsHitTarget(point);
377
- if (frameCheckResult === 'error:notconnected' || 'hitTargetDescription' in frameCheckResult) 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 this.evaluateHandleInUtility(([injected, node, {
381
- actionType,
382
- hitPoint,
383
- trial
384
- }]) => injected.setupHitTargetInterceptor(node, actionType, hitPoint, trial), {
385
- actionType,
386
- hitPoint,
387
- trial: !!options.trial
388
- });
389
- if (handle === 'error:notconnected') return handle;
390
- if (!handle._objectId) {
391
- const error = handle.rawValue();
392
- if (error === 'error:notconnected') return error;
393
- return {
394
- hitTargetDescription: error
395
- };
396
- }
397
- hitTargetInterceptionHandle = handle;
398
- progress.cleanupWhenAborted(() => {
399
- // Do not await here, just in case the renderer is stuck (e.g. on alert)
400
- // and we won't be able to cleanup.
401
- hitTargetInterceptionHandle.evaluate(h => h.stop()).catch(e => {});
402
- hitTargetInterceptionHandle.dispose();
403
- });
404
- }
405
- const actionResult = await this._page._frameManager.waitForSignalsCreatedBy(progress, options.waitAfter === true, async () => {
406
- if (options.__testHookBeforePointerAction) await options.__testHookBeforePointerAction();
407
- progress.throwIfAborted(); // Avoid action that has side-effects.
408
- let restoreModifiers;
409
- if (options && options.modifiers) restoreModifiers = await this._page.keyboard.ensureModifiers(options.modifiers);
410
- progress.log(` performing ${actionName} action`);
411
- await action(point);
412
- if (restoreModifiers) await this._page.keyboard.ensureModifiers(restoreModifiers);
413
- if (hitTargetInterceptionHandle) {
414
- const stopHitTargetInterception = this._frame.raceAgainstEvaluationStallingEvents(() => {
415
- return hitTargetInterceptionHandle.evaluate(h => h.stop());
416
- }).catch(e => 'done').finally(() => {
417
- var _hitTargetInterceptio;
418
- (_hitTargetInterceptio = hitTargetInterceptionHandle) === null || _hitTargetInterceptio === void 0 || _hitTargetInterceptio.dispose();
419
- });
420
- if (options.waitAfter !== false) {
421
- // When noWaitAfter is passed, we do not want to accidentally stall on
422
- // non-committed navigation blocking the evaluate.
423
- const hitTargetResult = await stopHitTargetInterception;
424
- if (hitTargetResult !== 'done') return hitTargetResult;
425
- }
426
- }
427
- progress.log(` ${options.trial ? 'trial ' : ''}${actionName} action done`);
428
- progress.log(' waiting for scheduled navigations to finish');
429
- if (options.__testHookAfterPointerAction) await options.__testHookAfterPointerAction();
430
- return 'done';
431
- });
432
- if (actionResult !== 'done') return actionResult;
433
- progress.log(' navigations have finished');
434
- return 'done';
435
- }
436
- async hover(metadata, options) {
437
- const controller = new _progress.ProgressController(metadata, this);
438
- return controller.run(async progress => {
439
- const result = await this._hover(progress, options);
440
- return assertDone(throwRetargetableDOMError(result));
441
- }, this._page._timeoutSettings.timeout(options));
442
- }
443
- _hover(progress, options) {
444
- return this._retryPointerAction(progress, 'hover', false /* waitForEnabled */, point => this._page.mouse.move(point.x, point.y), {
445
- ...options,
446
- waitAfter: 'disabled'
447
- });
448
- }
449
- async click(metadata, options = {}) {
450
- const controller = new _progress.ProgressController(metadata, this);
451
- return controller.run(async progress => {
452
- const result = await this._click(progress, {
453
- ...options,
454
- waitAfter: !options.noWaitAfter
455
- });
456
- return assertDone(throwRetargetableDOMError(result));
457
- }, this._page._timeoutSettings.timeout(options));
458
- }
459
- _click(progress, options) {
460
- return this._retryPointerAction(progress, 'click', true /* waitForEnabled */, point => this._page.mouse.click(point.x, point.y, options), options);
461
- }
462
- async dblclick(metadata, options) {
463
- const controller = new _progress.ProgressController(metadata, this);
464
- return controller.run(async progress => {
465
- const result = await this._dblclick(progress, options);
466
- return assertDone(throwRetargetableDOMError(result));
467
- }, this._page._timeoutSettings.timeout(options));
468
- }
469
- _dblclick(progress, options) {
470
- return this._retryPointerAction(progress, 'dblclick', true /* waitForEnabled */, point => this._page.mouse.dblclick(point.x, point.y, options), {
471
- ...options,
472
- waitAfter: 'disabled'
473
- });
474
- }
475
- async tap(metadata, options = {}) {
476
- const controller = new _progress.ProgressController(metadata, this);
477
- return controller.run(async progress => {
478
- const result = await this._tap(progress, options);
479
- return assertDone(throwRetargetableDOMError(result));
480
- }, this._page._timeoutSettings.timeout(options));
481
- }
482
- _tap(progress, options) {
483
- return this._retryPointerAction(progress, 'tap', true /* waitForEnabled */, point => this._page.touchscreen.tap(point.x, point.y), {
484
- ...options,
485
- waitAfter: 'disabled'
486
- });
487
- }
488
- async selectOption(metadata, elements, values, options) {
489
- const controller = new _progress.ProgressController(metadata, this);
490
- return controller.run(async progress => {
491
- const result = await this._selectOption(progress, elements, values, options);
492
- return throwRetargetableDOMError(result);
493
- }, this._page._timeoutSettings.timeout(options));
494
- }
495
- async _selectOption(progress, elements, values, options) {
496
- let resultingOptions = [];
497
- await this._retryAction(progress, 'select option', async () => {
498
- await progress.beforeInputAction(this);
499
- if (!options.force) progress.log(` waiting for element to be visible and enabled`);
500
- const optionsToSelect = [...elements, ...values];
501
- const result = await this.evaluateInUtility(async ([injected, node, {
502
- optionsToSelect,
503
- force
504
- }]) => {
505
- if (!force) {
506
- const checkResult = await injected.checkElementStates(node, ['visible', 'enabled']);
507
- if (checkResult) return checkResult;
508
- }
509
- return injected.selectOptions(node, optionsToSelect);
510
- }, {
511
- optionsToSelect,
512
- force: options.force
513
- });
514
- if (Array.isArray(result)) {
515
- progress.log(' selected specified option(s)');
516
- resultingOptions = result;
517
- return 'done';
518
- }
519
- return result;
520
- }, options);
521
- return resultingOptions;
522
- }
523
- async fill(metadata, value, options = {}) {
524
- const controller = new _progress.ProgressController(metadata, this);
525
- return controller.run(async progress => {
526
- const result = await this._fill(progress, value, options);
527
- assertDone(throwRetargetableDOMError(result));
528
- }, this._page._timeoutSettings.timeout(options));
529
- }
530
- async _fill(progress, value, options) {
531
- progress.log(` fill("${value}")`);
532
- return await this._retryAction(progress, 'fill', async () => {
533
- await progress.beforeInputAction(this);
534
- if (!options.force) progress.log(' waiting for element to be visible, enabled and editable');
535
- const result = await this.evaluateInUtility(async ([injected, node, {
536
- value,
537
- force
538
- }]) => {
539
- if (!force) {
540
- const checkResult = await injected.checkElementStates(node, ['visible', 'enabled', 'editable']);
541
- if (checkResult) return checkResult;
542
- }
543
- return injected.fill(node, value);
544
- }, {
545
- value,
546
- force: options.force
547
- });
548
- progress.throwIfAborted(); // Avoid action that has side-effects.
549
- if (result === 'needsinput') {
550
- if (value) await this._page.keyboard.insertText(value);else await this._page.keyboard.press('Delete');
551
- return 'done';
552
- } else {
553
- return result;
554
- }
555
- }, options);
556
- }
557
- async selectText(metadata, options = {}) {
558
- const controller = new _progress.ProgressController(metadata, this);
559
- return controller.run(async progress => {
560
- const result = await this._retryAction(progress, 'selectText', async () => {
561
- if (!options.force) progress.log(' waiting for element to be visible');
562
- return await this.evaluateInUtility(async ([injected, node, {
563
- force
564
- }]) => {
565
- if (!force) {
566
- const checkResult = await injected.checkElementStates(node, ['visible']);
567
- if (checkResult) return checkResult;
568
- }
569
- return injected.selectText(node);
570
- }, {
571
- force: options.force
572
- });
573
- }, options);
574
- assertDone(throwRetargetableDOMError(result));
575
- }, this._page._timeoutSettings.timeout(options));
576
- }
577
- async setInputFiles(metadata, params) {
578
- const inputFileItems = await (0, _fileUploadUtils.prepareFilesForUpload)(this._frame, params);
579
- const controller = new _progress.ProgressController(metadata, this);
580
- return controller.run(async progress => {
581
- const result = await this._setInputFiles(progress, inputFileItems);
582
- return assertDone(throwRetargetableDOMError(result));
583
- }, this._page._timeoutSettings.timeout(params));
584
- }
585
- async _setInputFiles(progress, items) {
586
- const {
587
- filePayloads,
588
- localPaths,
589
- localDirectory
590
- } = items;
591
- const multiple = filePayloads && filePayloads.length > 1 || localPaths && localPaths.length > 1;
592
- const result = await this.evaluateHandleInUtility(([injected, node, {
593
- multiple,
594
- directoryUpload
595
- }]) => {
596
- const element = injected.retarget(node, 'follow-label');
597
- if (!element) return;
598
- if (element.tagName !== 'INPUT') throw injected.createStacklessError('Node is not an HTMLInputElement');
599
- const inputElement = element;
600
- if (multiple && !inputElement.multiple && !inputElement.webkitdirectory) throw injected.createStacklessError('Non-multiple file input can only accept single file');
601
- if (directoryUpload && !inputElement.webkitdirectory) throw injected.createStacklessError('File input does not support directories, pass individual files instead');
602
- if (!directoryUpload && inputElement.webkitdirectory) throw injected.createStacklessError('[webkitdirectory] input requires passing a path to a directory');
603
- return inputElement;
604
- }, {
605
- multiple,
606
- directoryUpload: !!localDirectory
607
- });
608
- if (result === 'error:notconnected' || !result.asElement()) return 'error:notconnected';
609
- const retargeted = result.asElement();
610
- await progress.beforeInputAction(this);
611
- progress.throwIfAborted(); // Avoid action that has side-effects.
612
- if (localPaths || localDirectory) {
613
- const localPathsOrDirectory = localDirectory ? [localDirectory] : localPaths;
614
- await Promise.all(localPathsOrDirectory.map(localPath => _fs.default.promises.access(localPath, _fs.default.constants.F_OK)));
615
- // Browsers traverse the given directory asynchronously and we want to ensure all files are uploaded.
616
- const waitForInputEvent = localDirectory ? this.evaluate(node => new Promise(fulfill => {
617
- node.addEventListener('input', fulfill, {
618
- once: true
619
- });
620
- })).catch(() => {}) : Promise.resolve();
621
- await this._page._delegate.setInputFilePaths(retargeted, localPathsOrDirectory);
622
- await waitForInputEvent;
623
- } else {
624
- await this._page._delegate.setInputFiles(retargeted, filePayloads);
625
- }
626
- return 'done';
627
- }
628
- async focus(metadata) {
629
- const controller = new _progress.ProgressController(metadata, this);
630
- await controller.run(async progress => {
631
- const result = await this._focus(progress);
632
- return assertDone(throwRetargetableDOMError(result));
633
- }, 0);
634
- }
635
- async _focus(progress, resetSelectionIfNotFocused) {
636
- progress.throwIfAborted(); // Avoid action that has side-effects.
637
- return await this.evaluateInUtility(([injected, node, resetSelectionIfNotFocused]) => injected.focusNode(node, resetSelectionIfNotFocused), resetSelectionIfNotFocused);
638
- }
639
- async _blur(progress) {
640
- progress.throwIfAborted(); // Avoid action that has side-effects.
641
- return await this.evaluateInUtility(([injected, node]) => injected.blurNode(node), {});
642
- }
643
- async type(metadata, text, options) {
644
- const controller = new _progress.ProgressController(metadata, this);
645
- return controller.run(async progress => {
646
- const result = await this._type(progress, text, options);
647
- return assertDone(throwRetargetableDOMError(result));
648
- }, this._page._timeoutSettings.timeout(options));
649
- }
650
- async _type(progress, text, options) {
651
- progress.log(`elementHandle.type("${text}")`);
652
- await progress.beforeInputAction(this);
653
- const result = await this._focus(progress, true /* resetSelectionIfNotFocused */);
654
- if (result !== 'done') return result;
655
- progress.throwIfAborted(); // Avoid action that has side-effects.
656
- await this._page.keyboard.type(text, options);
657
- return 'done';
658
- }
659
- async press(metadata, key, options) {
660
- const controller = new _progress.ProgressController(metadata, this);
661
- return controller.run(async progress => {
662
- const result = await this._press(progress, key, options);
663
- return assertDone(throwRetargetableDOMError(result));
664
- }, this._page._timeoutSettings.timeout(options));
665
- }
666
- async _press(progress, key, options) {
667
- progress.log(`elementHandle.press("${key}")`);
668
- await progress.beforeInputAction(this);
669
- return this._page._frameManager.waitForSignalsCreatedBy(progress, !options.noWaitAfter, async () => {
670
- const result = await this._focus(progress, true /* resetSelectionIfNotFocused */);
671
- if (result !== 'done') return result;
672
- progress.throwIfAborted(); // Avoid action that has side-effects.
673
- await this._page.keyboard.press(key, options);
674
- return 'done';
675
- });
676
- }
677
- async check(metadata, options) {
678
- const controller = new _progress.ProgressController(metadata, this);
679
- return controller.run(async progress => {
680
- const result = await this._setChecked(progress, true, options);
681
- return assertDone(throwRetargetableDOMError(result));
682
- }, this._page._timeoutSettings.timeout(options));
683
- }
684
- async uncheck(metadata, options) {
685
- const controller = new _progress.ProgressController(metadata, this);
686
- return controller.run(async progress => {
687
- const result = await this._setChecked(progress, false, options);
688
- return assertDone(throwRetargetableDOMError(result));
689
- }, this._page._timeoutSettings.timeout(options));
690
- }
691
- async _setChecked(progress, state, options) {
692
- const isChecked = async () => {
693
- const result = await this.evaluateInUtility(([injected, node]) => injected.elementState(node, 'checked'), {});
694
- return throwRetargetableDOMError(result);
695
- };
696
- if ((await isChecked()) === state) return 'done';
697
- const result = await this._click(progress, {
698
- ...options,
699
- waitAfter: 'disabled'
700
- });
701
- if (result !== 'done') return result;
702
- if (options.trial) return 'done';
703
- if ((await isChecked()) !== state) throw new NonRecoverableDOMError('Clicking the checkbox did not change its state');
704
- return 'done';
705
- }
706
- async boundingBox() {
707
- return this._page._delegate.getBoundingBox(this);
708
- }
709
- async screenshot(metadata, options = {}) {
710
- const controller = new _progress.ProgressController(metadata, this);
711
- return controller.run(progress => this._page._screenshotter.screenshotElement(progress, this, options), this._page._timeoutSettings.timeout(options));
712
- }
713
- async querySelector(selector, options) {
714
- return this._frame.selectors.query(selector, options, this);
715
- }
716
- async querySelectorAll(selector) {
717
- return this._frame.selectors.queryAll(selector, this);
718
- }
719
- async evalOnSelector(selector, strict, expression, isFunction, arg) {
720
- return this._frame.evalOnSelector(selector, strict, expression, isFunction, arg, this);
721
- }
722
- async evalOnSelectorAll(selector, expression, isFunction, arg) {
723
- return this._frame.evalOnSelectorAll(selector, expression, isFunction, arg, this);
724
- }
725
- async isVisible(metadata) {
726
- return this._frame.isVisible(metadata, ':scope', {}, this);
727
- }
728
- async isHidden(metadata) {
729
- return this._frame.isHidden(metadata, ':scope', {}, this);
730
- }
731
- async isEnabled(metadata) {
732
- return this._frame.isEnabled(metadata, ':scope', {}, this);
733
- }
734
- async isDisabled(metadata) {
735
- return this._frame.isDisabled(metadata, ':scope', {}, this);
736
- }
737
- async isEditable(metadata) {
738
- return this._frame.isEditable(metadata, ':scope', {}, this);
739
- }
740
- async isChecked(metadata) {
741
- return this._frame.isChecked(metadata, ':scope', {}, this);
742
- }
743
- async waitForElementState(metadata, state, options = {}) {
744
- const controller = new _progress.ProgressController(metadata, this);
745
- return controller.run(async progress => {
746
- const actionName = `wait for ${state}`;
747
- const result = await this._retryAction(progress, actionName, async () => {
748
- return await this.evaluateInUtility(async ([injected, node, state]) => {
749
- return (await injected.checkElementStates(node, [state])) || 'done';
750
- }, state);
751
- }, {});
752
- assertDone(throwRetargetableDOMError(result));
753
- }, this._page._timeoutSettings.timeout(options));
754
- }
755
- async waitForSelector(metadata, selector, options = {}) {
756
- return this._frame.waitForSelector(metadata, selector, options, this);
757
- }
758
- async _adoptTo(context) {
759
- if (this._context !== context) {
760
- const adopted = await this._page._delegate.adoptElementHandle(this, context);
761
- this.dispose();
762
- return adopted;
763
- }
764
- return this;
765
- }
766
- async _checkFrameIsHitTarget(point) {
767
- let frame = this._frame;
768
- const data = [];
769
- while (frame.parentFrame()) {
770
- const frameElement = await frame.frameElement();
771
- const box = await frameElement.boundingBox();
772
- const style = await frameElement.evaluateInUtility(([injected, iframe]) => injected.describeIFrameStyle(iframe), {}).catch(e => 'error:notconnected');
773
- if (!box || style === 'error:notconnected') return 'error:notconnected';
774
- if (style === 'transformed') {
775
- // We cannot translate coordinates when iframe has any transform applied.
776
- // The best we can do right now is to skip the hitPoint check,
777
- // and solely rely on the event interceptor.
778
- return {
779
- framePoint: undefined
780
- };
781
- }
782
- // Translate from viewport coordinates to frame coordinates.
783
- const pointInFrame = {
784
- x: point.x - box.x - style.left,
785
- y: point.y - box.y - style.top
786
- };
787
- data.push({
788
- frame,
789
- frameElement,
790
- pointInFrame
791
- });
792
- frame = frame.parentFrame();
793
- }
794
- // Add main frame.
795
- data.push({
796
- frame,
797
- frameElement: null,
798
- pointInFrame: point
799
- });
800
- for (let i = data.length - 1; i > 0; i--) {
801
- const element = data[i - 1].frameElement;
802
- const point = data[i].pointInFrame;
803
- // Hit target in the parent frame should hit the child frame element.
804
- const hitTargetResult = await element.evaluateInUtility(([injected, element, hitPoint]) => {
805
- return injected.expectHitTarget(hitPoint, element);
806
- }, point);
807
- if (hitTargetResult !== 'done') return hitTargetResult;
808
- }
809
- return {
810
- framePoint: data[0].pointInFrame
811
- };
812
- }
813
- }
814
- exports.ElementHandle = ElementHandle;
815
- function throwRetargetableDOMError(result) {
816
- if (result === 'error:notconnected') throw new Error('Element is not attached to the DOM');
817
- return result;
818
- }
819
- function assertDone(result) {
820
- // This function converts 'done' to void and ensures typescript catches unhandled errors.
821
- }
822
- function roundPoint(point) {
823
- return {
824
- x: (point.x * 100 | 0) / 100,
825
- y: (point.y * 100 | 0) / 100
826
- };
827
- }
828
- function compensateHalfIntegerRoundingError(point) {
829
- // Firefox internally uses integer coordinates, so 8.5 is converted to 9 when clicking.
830
- //
831
- // This does not work nicely for small elements. For example, 1x1 square with corners
832
- // (8;8) and (9;9) is targeted when clicking at (8;8) but not when clicking at (9;9).
833
- // So, clicking at (8.5;8.5) will effectively click at (9;9) and miss the target.
834
- //
835
- // Therefore, we skew half-integer values from the interval (8.49, 8.51) towards
836
- // (8.47, 8.49) that is rounded towards 8. This means clicking at (8.5;8.5) will
837
- // be replaced with (8.48;8.48) and will effectively click at (8;8).
838
- //
839
- // Other browsers use float coordinates, so this change should not matter.
840
- const remainderX = point.x - Math.floor(point.x);
841
- if (remainderX > 0.49 && remainderX < 0.51) point.x -= 0.02;
842
- const remainderY = point.y - Math.floor(point.y);
843
- if (remainderY > 0.49 && remainderY < 0.51) point.y -= 0.02;
844
- }
845
- const kUnableToAdoptErrorMessage = exports.kUnableToAdoptErrorMessage = 'Unable to adopt element handle from a different document';