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,1654 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.NavigationAbortedError = exports.FrameManager = exports.Frame = void 0;
7
- var dom = _interopRequireWildcard(require("./dom"));
8
- var _helper = require("./helper");
9
- var _eventsHelper = require("../utils/eventsHelper");
10
- var js = _interopRequireWildcard(require("./javascript"));
11
- var network = _interopRequireWildcard(require("./network"));
12
- var _page = require("./page");
13
- var types = _interopRequireWildcard(require("./types"));
14
- var _browserContext = require("./browserContext");
15
- var _progress = require("./progress");
16
- var _utils = require("../utils");
17
- var _manualPromise = require("../utils/manualPromise");
18
- var _debugLogger = require("../utils/debugLogger");
19
- var _instrumentation = require("./instrumentation");
20
- var _protocolError = require("./protocolError");
21
- var _selectorParser = require("../utils/isomorphic/selectorParser");
22
- var _frameSelectors = require("./frameSelectors");
23
- var _errors = require("./errors");
24
- var _fileUploadUtils = require("./fileUploadUtils");
25
- 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); }
26
- 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; }
27
- /**
28
- * Copyright 2017 Google Inc. All rights reserved.
29
- * Modifications copyright (c) Microsoft Corporation.
30
- *
31
- * Licensed under the Apache License, Version 2.0 (the "License");
32
- * you may not use this file except in compliance with the License.
33
- * You may obtain a copy of the License at
34
- *
35
- * http://www.apache.org/licenses/LICENSE-2.0
36
- *
37
- * Unless required by applicable law or agreed to in writing, software
38
- * distributed under the License is distributed on an "AS IS" BASIS,
39
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
40
- * See the License for the specific language governing permissions and
41
- * limitations under the License.
42
- */
43
-
44
- class NavigationAbortedError extends Error {
45
- constructor(documentId, message) {
46
- super(message);
47
- this.documentId = void 0;
48
- this.documentId = documentId;
49
- }
50
- }
51
- exports.NavigationAbortedError = NavigationAbortedError;
52
- const kDummyFrameId = '<dummy>';
53
- class FrameManager {
54
- constructor(page) {
55
- this._page = void 0;
56
- this._frames = new Map();
57
- this._mainFrame = void 0;
58
- this._consoleMessageTags = new Map();
59
- this._signalBarriers = new Set();
60
- this._webSockets = new Map();
61
- this._openedDialogs = new Set();
62
- this._closeAllOpeningDialogs = false;
63
- this._page = page;
64
- this._mainFrame = undefined;
65
- }
66
- createDummyMainFrameIfNeeded() {
67
- if (!this._mainFrame) this.frameAttached(kDummyFrameId, null);
68
- }
69
- dispose() {
70
- for (const frame of this._frames.values()) {
71
- frame._stopNetworkIdleTimer();
72
- frame._invalidateNonStallingEvaluations('Target crashed');
73
- }
74
- }
75
- mainFrame() {
76
- return this._mainFrame;
77
- }
78
- frames() {
79
- const frames = [];
80
- collect(this._mainFrame);
81
- return frames;
82
- function collect(frame) {
83
- frames.push(frame);
84
- for (const subframe of frame.childFrames()) collect(subframe);
85
- }
86
- }
87
- frame(frameId) {
88
- return this._frames.get(frameId) || null;
89
- }
90
- frameAttached(frameId, parentFrameId) {
91
- const parentFrame = parentFrameId ? this._frames.get(parentFrameId) : null;
92
- if (!parentFrame) {
93
- if (this._mainFrame) {
94
- // Update frame id to retain frame identity on cross-process navigation.
95
- this._frames.delete(this._mainFrame._id);
96
- this._mainFrame._id = frameId;
97
- } else {
98
- (0, _utils.assert)(!this._frames.has(frameId));
99
- this._mainFrame = new Frame(this._page, frameId, parentFrame);
100
- }
101
- this._frames.set(frameId, this._mainFrame);
102
- return this._mainFrame;
103
- } else {
104
- (0, _utils.assert)(!this._frames.has(frameId));
105
- const frame = new Frame(this._page, frameId, parentFrame);
106
- this._frames.set(frameId, frame);
107
- this._page.emit(_page.Page.Events.FrameAttached, frame);
108
- return frame;
109
- }
110
- }
111
- async waitForSignalsCreatedBy(progress, waitAfter, action) {
112
- if (!waitAfter) return action();
113
- const barrier = new SignalBarrier(progress);
114
- this._signalBarriers.add(barrier);
115
- if (progress) progress.cleanupWhenAborted(() => this._signalBarriers.delete(barrier));
116
- const result = await action();
117
- await this._page._delegate.inputActionEpilogue();
118
- await barrier.waitFor();
119
- this._signalBarriers.delete(barrier);
120
- // Resolve in the next task, after all waitForNavigations.
121
- await new Promise((0, _utils.makeWaitForNextTask)());
122
- return result;
123
- }
124
- frameWillPotentiallyRequestNavigation() {
125
- for (const barrier of this._signalBarriers) barrier.retain();
126
- }
127
- frameDidPotentiallyRequestNavigation() {
128
- for (const barrier of this._signalBarriers) barrier.release();
129
- }
130
- frameRequestedNavigation(frameId, documentId) {
131
- const frame = this._frames.get(frameId);
132
- if (!frame) return;
133
- for (const barrier of this._signalBarriers) barrier.addFrameNavigation(frame);
134
- if (frame.pendingDocument() && frame.pendingDocument().documentId === documentId) {
135
- // Do not override request with undefined.
136
- return;
137
- }
138
- const request = documentId ? Array.from(frame._inflightRequests).find(request => request._documentId === documentId) : undefined;
139
- frame.setPendingDocument({
140
- documentId,
141
- request
142
- });
143
- }
144
- frameCommittedNewDocumentNavigation(frameId, url, name, documentId, initial) {
145
- const frame = this._frames.get(frameId);
146
- this.removeChildFramesRecursively(frame);
147
- this.clearWebSockets(frame);
148
- frame._url = url;
149
- frame._name = name;
150
- let keepPending;
151
- const pendingDocument = frame.pendingDocument();
152
- if (pendingDocument) {
153
- if (pendingDocument.documentId === undefined) {
154
- // Pending with unknown documentId - assume it is the one being committed.
155
- pendingDocument.documentId = documentId;
156
- }
157
- if (pendingDocument.documentId === documentId) {
158
- // Committing a pending document.
159
- frame._currentDocument = pendingDocument;
160
- } else {
161
- // Sometimes, we already have a new pending when the old one commits.
162
- // An example would be Chromium error page followed by a new navigation request,
163
- // where the error page commit arrives after Network.requestWillBeSent for the
164
- // new navigation.
165
- // We commit, but keep the pending request since it's not done yet.
166
- keepPending = pendingDocument;
167
- frame._currentDocument = {
168
- documentId,
169
- request: undefined
170
- };
171
- }
172
- frame.setPendingDocument(undefined);
173
- } else {
174
- // No pending - just commit a new document.
175
- frame._currentDocument = {
176
- documentId,
177
- request: undefined
178
- };
179
- }
180
- frame._onClearLifecycle();
181
- const navigationEvent = {
182
- url,
183
- name,
184
- newDocument: frame._currentDocument,
185
- isPublic: true
186
- };
187
- this._fireInternalFrameNavigation(frame, navigationEvent);
188
- if (!initial) {
189
- _debugLogger.debugLogger.log('api', ` navigated to "${url}"`);
190
- this._page.frameNavigatedToNewDocument(frame);
191
- }
192
- // Restore pending if any - see comments above about keepPending.
193
- frame.setPendingDocument(keepPending);
194
- }
195
- frameCommittedSameDocumentNavigation(frameId, url) {
196
- const frame = this._frames.get(frameId);
197
- if (!frame) return;
198
- frame._url = url;
199
- const navigationEvent = {
200
- url,
201
- name: frame._name,
202
- isPublic: true
203
- };
204
- this._fireInternalFrameNavigation(frame, navigationEvent);
205
- _debugLogger.debugLogger.log('api', ` navigated to "${url}"`);
206
- }
207
- frameAbortedNavigation(frameId, errorText, documentId) {
208
- const frame = this._frames.get(frameId);
209
- if (!frame || !frame.pendingDocument()) return;
210
- if (documentId !== undefined && frame.pendingDocument().documentId !== documentId) return;
211
- const navigationEvent = {
212
- url: frame._url,
213
- name: frame._name,
214
- newDocument: frame.pendingDocument(),
215
- error: new NavigationAbortedError(documentId, errorText),
216
- isPublic: !(documentId && frame._redirectedNavigations.has(documentId))
217
- };
218
- frame.setPendingDocument(undefined);
219
- this._fireInternalFrameNavigation(frame, navigationEvent);
220
- }
221
- frameDetached(frameId) {
222
- const frame = this._frames.get(frameId);
223
- if (frame) {
224
- this._removeFramesRecursively(frame);
225
- this._page.mainFrame()._recalculateNetworkIdle();
226
- }
227
- }
228
- frameLifecycleEvent(frameId, event) {
229
- const frame = this._frames.get(frameId);
230
- if (frame) frame._onLifecycleEvent(event);
231
- }
232
- requestStarted(request, route) {
233
- const frame = request.frame();
234
- this._inflightRequestStarted(request);
235
- if (request._documentId) frame.setPendingDocument({
236
- documentId: request._documentId,
237
- request
238
- });
239
- if (request._isFavicon) {
240
- route === null || route === void 0 || route.continue({
241
- isFallback: true
242
- }).catch(() => {});
243
- return;
244
- }
245
- this._page.emitOnContext(_browserContext.BrowserContext.Events.Request, request);
246
- if (route) {
247
- var _this$_page$_serverRe, _this$_page, _this$_page$_clientRe, _this$_page2, _this$_page$_browserC, _this$_page$_browserC2;
248
- const r = new network.Route(request, route);
249
- if ((_this$_page$_serverRe = (_this$_page = this._page)._serverRequestInterceptor) !== null && _this$_page$_serverRe !== void 0 && _this$_page$_serverRe.call(_this$_page, r, request)) return;
250
- if ((_this$_page$_clientRe = (_this$_page2 = this._page)._clientRequestInterceptor) !== null && _this$_page$_clientRe !== void 0 && _this$_page$_clientRe.call(_this$_page2, r, request)) return;
251
- if ((_this$_page$_browserC = (_this$_page$_browserC2 = this._page._browserContext)._requestInterceptor) !== null && _this$_page$_browserC !== void 0 && _this$_page$_browserC.call(_this$_page$_browserC2, r, request)) return;
252
- r.continue({
253
- isFallback: true
254
- }).catch(() => {});
255
- }
256
- }
257
- requestReceivedResponse(response) {
258
- if (response.request()._isFavicon) return;
259
- this._page.emitOnContext(_browserContext.BrowserContext.Events.Response, response);
260
- }
261
- reportRequestFinished(request, response) {
262
- this._inflightRequestFinished(request);
263
- if (request._isFavicon) return;
264
- this._page.emitOnContext(_browserContext.BrowserContext.Events.RequestFinished, {
265
- request,
266
- response
267
- });
268
- }
269
- requestFailed(request, canceled) {
270
- const frame = request.frame();
271
- this._inflightRequestFinished(request);
272
- if (frame.pendingDocument() && frame.pendingDocument().request === request) {
273
- let errorText = request.failure().errorText;
274
- if (canceled) errorText += '; maybe frame was detached?';
275
- this.frameAbortedNavigation(frame._id, errorText, frame.pendingDocument().documentId);
276
- }
277
- if (request._isFavicon) return;
278
- this._page.emitOnContext(_browserContext.BrowserContext.Events.RequestFailed, request);
279
- }
280
- dialogDidOpen(dialog) {
281
- // Any ongoing evaluations will be stalled until the dialog is closed.
282
- for (const frame of this._frames.values()) frame._invalidateNonStallingEvaluations('JavaScript dialog interrupted evaluation');
283
- if (this._closeAllOpeningDialogs) dialog.close().then(() => {});else this._openedDialogs.add(dialog);
284
- }
285
- dialogWillClose(dialog) {
286
- this._openedDialogs.delete(dialog);
287
- }
288
- async closeOpenDialogs() {
289
- await Promise.all([...this._openedDialogs].map(dialog => dialog.close())).catch(() => {});
290
- this._openedDialogs.clear();
291
- }
292
- setCloseAllOpeningDialogs(closeDialogs) {
293
- this._closeAllOpeningDialogs = closeDialogs;
294
- }
295
- removeChildFramesRecursively(frame) {
296
- for (const child of frame.childFrames()) this._removeFramesRecursively(child);
297
- }
298
- _removeFramesRecursively(frame) {
299
- this.removeChildFramesRecursively(frame);
300
- frame._onDetached();
301
- this._frames.delete(frame._id);
302
- if (!this._page.isClosed()) this._page.emit(_page.Page.Events.FrameDetached, frame);
303
- }
304
- _inflightRequestFinished(request) {
305
- const frame = request.frame();
306
- if (request._isFavicon) return;
307
- if (!frame._inflightRequests.has(request)) return;
308
- frame._inflightRequests.delete(request);
309
- if (frame._inflightRequests.size === 0) frame._startNetworkIdleTimer();
310
- }
311
- _inflightRequestStarted(request) {
312
- const frame = request.frame();
313
- if (request._isFavicon) return;
314
- frame._inflightRequests.add(request);
315
- if (frame._inflightRequests.size === 1) frame._stopNetworkIdleTimer();
316
- }
317
- interceptConsoleMessage(message) {
318
- if (message.type() !== 'debug') return false;
319
- const tag = message.text();
320
- const handler = this._consoleMessageTags.get(tag);
321
- if (!handler) return false;
322
- this._consoleMessageTags.delete(tag);
323
- handler();
324
- return true;
325
- }
326
- clearWebSockets(frame) {
327
- // TODO: attribute sockets to frames.
328
- if (frame.parentFrame()) return;
329
- this._webSockets.clear();
330
- }
331
- onWebSocketCreated(requestId, url) {
332
- const ws = new network.WebSocket(this._page, url);
333
- this._webSockets.set(requestId, ws);
334
- }
335
- onWebSocketRequest(requestId) {
336
- const ws = this._webSockets.get(requestId);
337
- if (ws && ws.markAsNotified()) this._page.emit(_page.Page.Events.WebSocket, ws);
338
- }
339
- onWebSocketResponse(requestId, status, statusText) {
340
- const ws = this._webSockets.get(requestId);
341
- if (status < 400) return;
342
- if (ws) ws.error(`${statusText}: ${status}`);
343
- }
344
- onWebSocketFrameSent(requestId, opcode, data) {
345
- const ws = this._webSockets.get(requestId);
346
- if (ws) ws.frameSent(opcode, data);
347
- }
348
- webSocketFrameReceived(requestId, opcode, data) {
349
- const ws = this._webSockets.get(requestId);
350
- if (ws) ws.frameReceived(opcode, data);
351
- }
352
- webSocketClosed(requestId) {
353
- const ws = this._webSockets.get(requestId);
354
- if (ws) ws.closed();
355
- this._webSockets.delete(requestId);
356
- }
357
- webSocketError(requestId, errorMessage) {
358
- const ws = this._webSockets.get(requestId);
359
- if (ws) ws.error(errorMessage);
360
- }
361
- _fireInternalFrameNavigation(frame, event) {
362
- frame.emit(Frame.Events.InternalNavigation, event);
363
- }
364
- }
365
- exports.FrameManager = FrameManager;
366
- class Frame extends _instrumentation.SdkObject {
367
- constructor(page, id, parentFrame) {
368
- super(page, 'frame');
369
- this._id = void 0;
370
- this._firedLifecycleEvents = new Set();
371
- this._firedNetworkIdleSelf = false;
372
- this._currentDocument = void 0;
373
- this._pendingDocument = void 0;
374
- this._page = void 0;
375
- this._parentFrame = void 0;
376
- this._url = '';
377
- this._contextData = new Map();
378
- this._childFrames = new Set();
379
- this._name = '';
380
- this._inflightRequests = new Set();
381
- this._networkIdleTimer = void 0;
382
- this._setContentCounter = 0;
383
- this._detachedScope = new _utils.LongStandingScope();
384
- this._raceAgainstEvaluationStallingEventsPromises = new Set();
385
- this._redirectedNavigations = new Map();
386
- // documentId -> data
387
- this.selectors = void 0;
388
- this.attribution.frame = this;
389
- this._id = id;
390
- this._page = page;
391
- this._parentFrame = parentFrame;
392
- this._currentDocument = {
393
- documentId: undefined,
394
- request: undefined
395
- };
396
- this.selectors = new _frameSelectors.FrameSelectors(this);
397
- this._contextData.set('main', {
398
- contextPromise: new _manualPromise.ManualPromise(),
399
- context: null
400
- });
401
- this._contextData.set('utility', {
402
- contextPromise: new _manualPromise.ManualPromise(),
403
- context: null
404
- });
405
- this._setContext('main', null);
406
- this._setContext('utility', null);
407
- if (this._parentFrame) this._parentFrame._childFrames.add(this);
408
- this._firedLifecycleEvents.add('commit');
409
- if (id !== kDummyFrameId) this._startNetworkIdleTimer();
410
- }
411
- isDetached() {
412
- return this._detachedScope.isClosed();
413
- }
414
- _onLifecycleEvent(event) {
415
- if (this._firedLifecycleEvents.has(event)) return;
416
- this._firedLifecycleEvents.add(event);
417
- this.emit(Frame.Events.AddLifecycle, event);
418
- if (this === this._page.mainFrame() && this._url !== 'about:blank') _debugLogger.debugLogger.log('api', ` "${event}" event fired`);
419
- this._page.mainFrame()._recalculateNetworkIdle();
420
- }
421
- _onClearLifecycle() {
422
- for (const event of this._firedLifecycleEvents) this.emit(Frame.Events.RemoveLifecycle, event);
423
- this._firedLifecycleEvents.clear();
424
- // Keep the current navigation request if any.
425
- this._inflightRequests = new Set(Array.from(this._inflightRequests).filter(request => request === this._currentDocument.request));
426
- this._stopNetworkIdleTimer();
427
- if (this._inflightRequests.size === 0) this._startNetworkIdleTimer();
428
- this._page.mainFrame()._recalculateNetworkIdle(this);
429
- this._onLifecycleEvent('commit');
430
- }
431
- setPendingDocument(documentInfo) {
432
- this._pendingDocument = documentInfo;
433
- if (documentInfo) this._invalidateNonStallingEvaluations('Navigation interrupted the evaluation');
434
- }
435
- pendingDocument() {
436
- return this._pendingDocument;
437
- }
438
- _invalidateNonStallingEvaluations(message) {
439
- if (!this._raceAgainstEvaluationStallingEventsPromises.size) return;
440
- const error = new Error(message);
441
- for (const promise of this._raceAgainstEvaluationStallingEventsPromises) promise.reject(error);
442
- }
443
- async raceAgainstEvaluationStallingEvents(cb) {
444
- if (this._pendingDocument) throw new Error('Frame is currently attempting a navigation');
445
- if (this._page._frameManager._openedDialogs.size) throw new Error('Open JavaScript dialog prevents evaluation');
446
- const promise = new _manualPromise.ManualPromise();
447
- this._raceAgainstEvaluationStallingEventsPromises.add(promise);
448
- try {
449
- return await Promise.race([cb(), promise]);
450
- } finally {
451
- this._raceAgainstEvaluationStallingEventsPromises.delete(promise);
452
- }
453
- }
454
- nonStallingRawEvaluateInExistingMainContext(expression) {
455
- return this.raceAgainstEvaluationStallingEvents(() => {
456
- const context = this._existingMainContext();
457
- if (!context) throw new Error('Frame does not yet have a main execution context');
458
- return context.rawEvaluateJSON(expression);
459
- });
460
- }
461
- nonStallingEvaluateInExistingContext(expression, world) {
462
- return this.raceAgainstEvaluationStallingEvents(() => {
463
- var _this$_contextData$ge;
464
- const context = (_this$_contextData$ge = this._contextData.get(world)) === null || _this$_contextData$ge === void 0 ? void 0 : _this$_contextData$ge.context;
465
- if (!context) throw new Error('Frame does not yet have the execution context');
466
- return context.evaluateExpression(expression, {
467
- isFunction: false
468
- });
469
- });
470
- }
471
- _recalculateNetworkIdle(frameThatAllowsRemovingNetworkIdle) {
472
- let isNetworkIdle = this._firedNetworkIdleSelf;
473
- for (const child of this._childFrames) {
474
- child._recalculateNetworkIdle(frameThatAllowsRemovingNetworkIdle);
475
- // We require networkidle event to be fired in the whole frame subtree, and then consider it done.
476
- if (!child._firedLifecycleEvents.has('networkidle')) isNetworkIdle = false;
477
- }
478
- if (isNetworkIdle && !this._firedLifecycleEvents.has('networkidle')) {
479
- this._firedLifecycleEvents.add('networkidle');
480
- this.emit(Frame.Events.AddLifecycle, 'networkidle');
481
- if (this === this._page.mainFrame() && this._url !== 'about:blank') _debugLogger.debugLogger.log('api', ` "networkidle" event fired`);
482
- }
483
- if (frameThatAllowsRemovingNetworkIdle !== this && this._firedLifecycleEvents.has('networkidle') && !isNetworkIdle) {
484
- // Usually, networkidle is fired once and not removed after that.
485
- // However, when we clear them right before a new commit, this is allowed for a particular frame.
486
- this._firedLifecycleEvents.delete('networkidle');
487
- this.emit(Frame.Events.RemoveLifecycle, 'networkidle');
488
- }
489
- }
490
- async raceNavigationAction(progress, options, action) {
491
- return _utils.LongStandingScope.raceMultiple([this._detachedScope, this._page.openScope], action().catch(e => {
492
- if (e instanceof NavigationAbortedError && e.documentId) {
493
- const data = this._redirectedNavigations.get(e.documentId);
494
- if (data) {
495
- progress.log(`waiting for redirected navigation to "${data.url}"`);
496
- return data.gotoPromise;
497
- }
498
- }
499
- throw e;
500
- }));
501
- }
502
- redirectNavigation(url, documentId, referer) {
503
- const controller = new _progress.ProgressController((0, _instrumentation.serverSideCallMetadata)(), this);
504
- const data = {
505
- url,
506
- gotoPromise: controller.run(progress => this._gotoAction(progress, url, {
507
- referer
508
- }), 0)
509
- };
510
- this._redirectedNavigations.set(documentId, data);
511
- data.gotoPromise.finally(() => this._redirectedNavigations.delete(documentId));
512
- }
513
- async goto(metadata, url, options = {}) {
514
- const constructedNavigationURL = (0, _utils.constructURLBasedOnBaseURL)(this._page._browserContext._options.baseURL, url);
515
- const controller = new _progress.ProgressController(metadata, this);
516
- return controller.run(progress => this._goto(progress, constructedNavigationURL, options), this._page._timeoutSettings.navigationTimeout(options));
517
- }
518
- async _goto(progress, url, options) {
519
- return this.raceNavigationAction(progress, options, async () => this._gotoAction(progress, url, options));
520
- }
521
- async _gotoAction(progress, url, options) {
522
- const waitUntil = verifyLifecycle('waitUntil', options.waitUntil === undefined ? 'load' : options.waitUntil);
523
- progress.log(`navigating to "${url}", waiting until "${waitUntil}"`);
524
- const headers = this._page.extraHTTPHeaders() || [];
525
- const refererHeader = headers.find(h => h.name.toLowerCase() === 'referer');
526
- let referer = refererHeader ? refererHeader.value : undefined;
527
- if (options.referer !== undefined) {
528
- if (referer !== undefined && referer !== options.referer) throw new Error('"referer" is already specified as extra HTTP header');
529
- referer = options.referer;
530
- }
531
- url = _helper.helper.completeUserURL(url);
532
- const navigationEvents = [];
533
- const collectNavigations = arg => navigationEvents.push(arg);
534
- this.on(Frame.Events.InternalNavigation, collectNavigations);
535
- const navigateResult = await this._page._delegate.navigateFrame(this, url, referer).finally(() => this.off(Frame.Events.InternalNavigation, collectNavigations));
536
- let event;
537
- if (navigateResult.newDocumentId) {
538
- const predicate = event => {
539
- // We are interested either in this specific document, or any other document that
540
- // did commit and replaced the expected document.
541
- return event.newDocument && (event.newDocument.documentId === navigateResult.newDocumentId || !event.error);
542
- };
543
- const events = navigationEvents.filter(predicate);
544
- if (events.length) event = events[0];else event = await _helper.helper.waitForEvent(progress, this, Frame.Events.InternalNavigation, predicate).promise;
545
- if (event.newDocument.documentId !== navigateResult.newDocumentId) {
546
- // This is just a sanity check. In practice, new navigation should
547
- // cancel the previous one and report "request cancelled"-like error.
548
- throw new NavigationAbortedError(navigateResult.newDocumentId, `Navigation to "${url}" is interrupted by another navigation to "${event.url}"`);
549
- }
550
- if (event.error) throw event.error;
551
- } else {
552
- // Wait for same document navigation.
553
- const predicate = e => !e.newDocument;
554
- const events = navigationEvents.filter(predicate);
555
- if (events.length) event = events[0];else event = await _helper.helper.waitForEvent(progress, this, Frame.Events.InternalNavigation, predicate).promise;
556
- }
557
- if (!this._firedLifecycleEvents.has(waitUntil)) await _helper.helper.waitForEvent(progress, this, Frame.Events.AddLifecycle, e => e === waitUntil).promise;
558
- const request = event.newDocument ? event.newDocument.request : undefined;
559
- const response = request ? request._finalRequest().response() : null;
560
- return response;
561
- }
562
- async _waitForNavigation(progress, requiresNewDocument, options) {
563
- const waitUntil = verifyLifecycle('waitUntil', options.waitUntil === undefined ? 'load' : options.waitUntil);
564
- progress.log(`waiting for navigation until "${waitUntil}"`);
565
- const navigationEvent = await _helper.helper.waitForEvent(progress, this, Frame.Events.InternalNavigation, event => {
566
- // Any failed navigation results in a rejection.
567
- if (event.error) return true;
568
- if (requiresNewDocument && !event.newDocument) return false;
569
- progress.log(` navigated to "${this._url}"`);
570
- return true;
571
- }).promise;
572
- if (navigationEvent.error) throw navigationEvent.error;
573
- if (!this._firedLifecycleEvents.has(waitUntil)) await _helper.helper.waitForEvent(progress, this, Frame.Events.AddLifecycle, e => e === waitUntil).promise;
574
- const request = navigationEvent.newDocument ? navigationEvent.newDocument.request : undefined;
575
- return request ? request._finalRequest().response() : null;
576
- }
577
- async _waitForLoadState(progress, state) {
578
- const waitUntil = verifyLifecycle('state', state);
579
- if (!this._firedLifecycleEvents.has(waitUntil)) await _helper.helper.waitForEvent(progress, this, Frame.Events.AddLifecycle, e => e === waitUntil).promise;
580
- }
581
- async frameElement() {
582
- return this._page._delegate.getFrameElement(this);
583
- }
584
- _context(world) {
585
- return this._contextData.get(world).contextPromise.then(contextOrDestroyedReason => {
586
- if (contextOrDestroyedReason instanceof js.ExecutionContext) return contextOrDestroyedReason;
587
- throw new Error(contextOrDestroyedReason.destroyedReason);
588
- });
589
- }
590
- _mainContext() {
591
- return this._context('main');
592
- }
593
- _existingMainContext() {
594
- var _this$_contextData$ge2;
595
- return ((_this$_contextData$ge2 = this._contextData.get('main')) === null || _this$_contextData$ge2 === void 0 ? void 0 : _this$_contextData$ge2.context) || null;
596
- }
597
- _utilityContext() {
598
- return this._context('utility');
599
- }
600
- async evaluateExpression(expression, options = {}, arg) {
601
- var _options$world;
602
- const context = await this._context((_options$world = options.world) !== null && _options$world !== void 0 ? _options$world : 'main');
603
- const value = await context.evaluateExpression(expression, options, arg);
604
- return value;
605
- }
606
- async evaluateExpressionHandle(expression, options = {}, arg) {
607
- var _options$world2;
608
- const context = await this._context((_options$world2 = options.world) !== null && _options$world2 !== void 0 ? _options$world2 : 'main');
609
- const value = await context.evaluateExpressionHandle(expression, options, arg);
610
- return value;
611
- }
612
- async querySelector(selector, options) {
613
- _debugLogger.debugLogger.log('api', ` finding element using the selector "${selector}"`);
614
- return this.selectors.query(selector, options);
615
- }
616
- async waitForSelector(metadata, selector, options, scope) {
617
- const controller = new _progress.ProgressController(metadata, this);
618
- if (options.visibility) throw new Error('options.visibility is not supported, did you mean options.state?');
619
- if (options.waitFor && options.waitFor !== 'visible') throw new Error('options.waitFor is not supported, did you mean options.state?');
620
- const {
621
- state = 'visible'
622
- } = options;
623
- if (!['attached', 'detached', 'visible', 'hidden'].includes(state)) throw new Error(`state: expected one of (attached|detached|visible|hidden)`);
624
- return controller.run(async progress => {
625
- progress.log(`waiting for ${this._asLocator(selector)}${state === 'attached' ? '' : ' to be ' + state}`);
626
- return await this.waitForSelectorInternal(progress, selector, options, scope);
627
- }, this._page._timeoutSettings.timeout(options));
628
- }
629
- async waitForSelectorInternal(progress, selector, options, scope) {
630
- const {
631
- state = 'visible'
632
- } = options;
633
- const promise = this.retryWithProgressAndTimeouts(progress, [0, 20, 50, 100, 100, 500], async continuePolling => {
634
- const resolved = await this.selectors.resolveInjectedForSelector(selector, options, scope);
635
- progress.throwIfAborted();
636
- if (!resolved) {
637
- if (state === 'hidden' || state === 'detached') return null;
638
- return continuePolling;
639
- }
640
- const result = await resolved.injected.evaluateHandle((injected, {
641
- info,
642
- root
643
- }) => {
644
- const elements = injected.querySelectorAll(info.parsed, root || document);
645
- const element = elements[0];
646
- const visible = element ? injected.utils.isElementVisible(element) : false;
647
- let log = '';
648
- if (elements.length > 1) {
649
- if (info.strict) throw injected.strictModeViolationError(info.parsed, elements);
650
- log = ` locator resolved to ${elements.length} elements. Proceeding with the first one: ${injected.previewNode(elements[0])}`;
651
- } else if (element) {
652
- log = ` locator resolved to ${visible ? 'visible' : 'hidden'} ${injected.previewNode(element)}`;
653
- }
654
- return {
655
- log,
656
- element,
657
- visible,
658
- attached: !!element
659
- };
660
- }, {
661
- info: resolved.info,
662
- root: resolved.frame === this ? scope : undefined
663
- });
664
- const {
665
- log,
666
- visible,
667
- attached
668
- } = await result.evaluate(r => ({
669
- log: r.log,
670
- visible: r.visible,
671
- attached: r.attached
672
- }));
673
- if (log) progress.log(log);
674
- const success = {
675
- attached,
676
- detached: !attached,
677
- visible,
678
- hidden: !visible
679
- }[state];
680
- if (!success) {
681
- result.dispose();
682
- return continuePolling;
683
- }
684
- if (options.omitReturnValue) {
685
- result.dispose();
686
- return null;
687
- }
688
- const element = state === 'attached' || state === 'visible' ? await result.evaluateHandle(r => r.element) : null;
689
- result.dispose();
690
- if (!element) return null;
691
- if (options.__testHookBeforeAdoptNode) await options.__testHookBeforeAdoptNode();
692
- try {
693
- return await element._adoptTo(await resolved.frame._mainContext());
694
- } catch (e) {
695
- return continuePolling;
696
- }
697
- });
698
- return scope ? scope._context._raceAgainstContextDestroyed(promise) : promise;
699
- }
700
- async dispatchEvent(metadata, selector, type, eventInit = {}, options = {}, scope) {
701
- await this._callOnElementOnceMatches(metadata, selector, (injectedScript, element, data) => {
702
- injectedScript.dispatchEvent(element, data.type, data.eventInit);
703
- }, {
704
- type,
705
- eventInit
706
- }, {
707
- mainWorld: true,
708
- ...options
709
- }, scope);
710
- }
711
- async evalOnSelector(selector, strict, expression, isFunction, arg, scope) {
712
- const handle = await this.selectors.query(selector, {
713
- strict
714
- }, scope);
715
- if (!handle) throw new Error(`Failed to find element matching selector "${selector}"`);
716
- const result = await handle.evaluateExpression(expression, {
717
- isFunction
718
- }, arg);
719
- handle.dispose();
720
- return result;
721
- }
722
- async evalOnSelectorAll(selector, expression, isFunction, arg, scope) {
723
- const arrayHandle = await this.selectors.queryArrayInMainWorld(selector, scope);
724
- const result = await arrayHandle.evaluateExpression(expression, {
725
- isFunction
726
- }, arg);
727
- arrayHandle.dispose();
728
- return result;
729
- }
730
- async maskSelectors(selectors, color) {
731
- const context = await this._utilityContext();
732
- const injectedScript = await context.injectedScript();
733
- await injectedScript.evaluate((injected, {
734
- parsed,
735
- color
736
- }) => {
737
- injected.maskSelectors(parsed, color);
738
- }, {
739
- parsed: selectors,
740
- color: color
741
- });
742
- }
743
- async querySelectorAll(selector) {
744
- return this.selectors.queryAll(selector);
745
- }
746
- async queryCount(selector) {
747
- return await this.selectors.queryCount(selector);
748
- }
749
- async content() {
750
- try {
751
- const context = await this._utilityContext();
752
- return await context.evaluate(() => {
753
- let retVal = '';
754
- if (document.doctype) retVal = new XMLSerializer().serializeToString(document.doctype);
755
- if (document.documentElement) retVal += document.documentElement.outerHTML;
756
- return retVal;
757
- });
758
- } catch (e) {
759
- if (js.isJavaScriptErrorInEvaluate(e) || (0, _protocolError.isSessionClosedError)(e)) throw e;
760
- throw new Error(`Unable to retrieve content because the page is navigating and changing the content.`);
761
- }
762
- }
763
- async setContent(metadata, html, options = {}) {
764
- const controller = new _progress.ProgressController(metadata, this);
765
- return controller.run(async progress => {
766
- await this.raceNavigationAction(progress, options, async () => {
767
- var _this$_page$_delegate, _this$_page$_delegate2;
768
- const waitUntil = options.waitUntil === undefined ? 'load' : options.waitUntil;
769
- progress.log(`setting frame content, waiting until "${waitUntil}"`);
770
- const tag = `--playwright--set--content--${this._id}--${++this._setContentCounter}--`;
771
- const context = (_this$_page$_delegate = (_this$_page$_delegate2 = this._page._delegate).useMainWorldForSetContent) !== null && _this$_page$_delegate !== void 0 && _this$_page$_delegate.call(_this$_page$_delegate2) ? await this._mainContext() : await this._utilityContext();
772
- const lifecyclePromise = new Promise((resolve, reject) => {
773
- this._page._frameManager._consoleMessageTags.set(tag, () => {
774
- // Clear lifecycle right after document.open() - see 'tag' below.
775
- this._onClearLifecycle();
776
- this._waitForLoadState(progress, waitUntil).then(resolve).catch(reject);
777
- });
778
- });
779
- const contentPromise = context.evaluate(({
780
- html,
781
- tag
782
- }) => {
783
- document.open();
784
- console.debug(tag); // eslint-disable-line no-console
785
- document.write(html);
786
- document.close();
787
- }, {
788
- html,
789
- tag
790
- });
791
- await Promise.all([contentPromise, lifecyclePromise]);
792
- return null;
793
- });
794
- }, this._page._timeoutSettings.navigationTimeout(options));
795
- }
796
- name() {
797
- return this._name || '';
798
- }
799
- url() {
800
- return this._url;
801
- }
802
- origin() {
803
- var _network$parsedURL;
804
- if (!this._url.startsWith('http')) return;
805
- return (_network$parsedURL = network.parsedURL(this._url)) === null || _network$parsedURL === void 0 ? void 0 : _network$parsedURL.origin;
806
- }
807
- parentFrame() {
808
- return this._parentFrame;
809
- }
810
- childFrames() {
811
- return Array.from(this._childFrames);
812
- }
813
- async addScriptTag(params) {
814
- const {
815
- url = null,
816
- content = null,
817
- type = ''
818
- } = params;
819
- if (!url && !content) throw new Error('Provide an object with a `url`, `path` or `content` property');
820
- const context = await this._mainContext();
821
- return this._raceWithCSPError(async () => {
822
- if (url !== null) return (await context.evaluateHandle(addScriptUrl, {
823
- url,
824
- type
825
- })).asElement();
826
- const result = (await context.evaluateHandle(addScriptContent, {
827
- content: content,
828
- type
829
- })).asElement();
830
- // Another round trip to the browser to ensure that we receive CSP error messages
831
- // (if any) logged asynchronously in a separate task on the content main thread.
832
- if (this._page._delegate.cspErrorsAsynchronousForInlineScripts) await context.evaluate(() => true);
833
- return result;
834
- });
835
- async function addScriptUrl(params) {
836
- const script = document.createElement('script');
837
- script.src = params.url;
838
- if (params.type) script.type = params.type;
839
- const promise = new Promise((res, rej) => {
840
- script.onload = res;
841
- script.onerror = e => rej(typeof e === 'string' ? new Error(e) : new Error(`Failed to load script at ${script.src}`));
842
- });
843
- document.head.appendChild(script);
844
- await promise;
845
- return script;
846
- }
847
- function addScriptContent(params) {
848
- const script = document.createElement('script');
849
- script.type = params.type || 'text/javascript';
850
- script.text = params.content;
851
- let error = null;
852
- script.onerror = e => error = e;
853
- document.head.appendChild(script);
854
- if (error) throw error;
855
- return script;
856
- }
857
- }
858
- async addStyleTag(params) {
859
- const {
860
- url = null,
861
- content = null
862
- } = params;
863
- if (!url && !content) throw new Error('Provide an object with a `url`, `path` or `content` property');
864
- const context = await this._mainContext();
865
- return this._raceWithCSPError(async () => {
866
- if (url !== null) return (await context.evaluateHandle(addStyleUrl, url)).asElement();
867
- return (await context.evaluateHandle(addStyleContent, content)).asElement();
868
- });
869
- async function addStyleUrl(url) {
870
- const link = document.createElement('link');
871
- link.rel = 'stylesheet';
872
- link.href = url;
873
- const promise = new Promise((res, rej) => {
874
- link.onload = res;
875
- link.onerror = rej;
876
- });
877
- document.head.appendChild(link);
878
- await promise;
879
- return link;
880
- }
881
- async function addStyleContent(content) {
882
- const style = document.createElement('style');
883
- style.type = 'text/css';
884
- style.appendChild(document.createTextNode(content));
885
- const promise = new Promise((res, rej) => {
886
- style.onload = res;
887
- style.onerror = rej;
888
- });
889
- document.head.appendChild(style);
890
- await promise;
891
- return style;
892
- }
893
- }
894
- async _raceWithCSPError(func) {
895
- const listeners = [];
896
- let result;
897
- let error;
898
- let cspMessage;
899
- const actionPromise = func().then(r => result = r).catch(e => error = e);
900
- const errorPromise = new Promise(resolve => {
901
- listeners.push(_eventsHelper.eventsHelper.addEventListener(this._page._browserContext, _browserContext.BrowserContext.Events.Console, message => {
902
- if (message.page() !== this._page || message.type() !== 'error') return;
903
- if (message.text().includes('Content-Security-Policy') || message.text().includes('Content Security Policy')) {
904
- cspMessage = message;
905
- resolve();
906
- }
907
- }));
908
- });
909
- await Promise.race([actionPromise, errorPromise]);
910
- _eventsHelper.eventsHelper.removeEventListeners(listeners);
911
- if (cspMessage) throw new Error(cspMessage.text());
912
- if (error) throw error;
913
- return result;
914
- }
915
- async retryWithProgressAndTimeouts(progress, timeouts, action) {
916
- const continuePolling = Symbol('continuePolling');
917
- timeouts = [0, ...timeouts];
918
- let timeoutIndex = 0;
919
- while (progress.isRunning()) {
920
- const timeout = timeouts[Math.min(timeoutIndex++, timeouts.length - 1)];
921
- if (timeout) {
922
- // Make sure we react immediately upon page close or frame detach.
923
- // We need this to show expected/received values in time.
924
- const actionPromise = new Promise(f => setTimeout(f, timeout));
925
- await _utils.LongStandingScope.raceMultiple([this._page.openScope, this._detachedScope], actionPromise);
926
- }
927
- progress.throwIfAborted();
928
- try {
929
- const result = await action(continuePolling);
930
- if (result === continuePolling) continue;
931
- return result;
932
- } catch (e) {
933
- if (this._isErrorThatCannotBeRetried(e)) throw e;
934
- continue;
935
- }
936
- }
937
- progress.throwIfAborted();
938
- return undefined;
939
- }
940
- _isErrorThatCannotBeRetried(e) {
941
- // Always fail on JavaScript errors or when the main connection is closed.
942
- if (js.isJavaScriptErrorInEvaluate(e) || (0, _protocolError.isSessionClosedError)(e)) return true;
943
- // Certain errors opt-out of the retries, throw.
944
- if (dom.isNonRecoverableDOMError(e) || (0, _selectorParser.isInvalidSelectorError)(e)) return true;
945
- // If the call is made on the detached frame - throw.
946
- if (this.isDetached()) return true;
947
- // Retry upon all other errors.
948
- return false;
949
- }
950
- async _retryWithProgressIfNotConnected(progress, selector, strict, performLocatorHandlersCheckpoint, action) {
951
- progress.log(`waiting for ${this._asLocator(selector)}`);
952
- return this.retryWithProgressAndTimeouts(progress, [0, 20, 50, 100, 100, 500], async continuePolling => {
953
- if (performLocatorHandlersCheckpoint) await this._page.performLocatorHandlersCheckpoint(progress);
954
- const resolved = await this.selectors.resolveInjectedForSelector(selector, {
955
- strict
956
- });
957
- progress.throwIfAborted();
958
- if (!resolved) return continuePolling;
959
- const result = await resolved.injected.evaluateHandle((injected, {
960
- info
961
- }) => {
962
- const elements = injected.querySelectorAll(info.parsed, document);
963
- const element = elements[0];
964
- let log = '';
965
- if (elements.length > 1) {
966
- if (info.strict) throw injected.strictModeViolationError(info.parsed, elements);
967
- log = ` locator resolved to ${elements.length} elements. Proceeding with the first one: ${injected.previewNode(elements[0])}`;
968
- } else if (element) {
969
- log = ` locator resolved to ${injected.previewNode(element)}`;
970
- }
971
- return {
972
- log,
973
- success: !!element,
974
- element
975
- };
976
- }, {
977
- info: resolved.info
978
- });
979
- const {
980
- log,
981
- success
982
- } = await result.evaluate(r => ({
983
- log: r.log,
984
- success: r.success
985
- }));
986
- if (log) progress.log(log);
987
- if (!success) {
988
- result.dispose();
989
- return continuePolling;
990
- }
991
- const element = await result.evaluateHandle(r => r.element);
992
- result.dispose();
993
- try {
994
- const result = await action(element);
995
- if (result === 'error:notconnected') {
996
- progress.log('element was detached from the DOM, retrying');
997
- return continuePolling;
998
- }
999
- return result;
1000
- } finally {
1001
- element === null || element === void 0 || element.dispose();
1002
- }
1003
- });
1004
- }
1005
- async rafrafTimeoutScreenshotElementWithProgress(progress, selector, timeout, options) {
1006
- return await this._retryWithProgressIfNotConnected(progress, selector, true /* strict */, true /* performLocatorHandlersCheckpoint */, async handle => {
1007
- await handle._frame.rafrafTimeout(timeout);
1008
- return await this._page._screenshotter.screenshotElement(progress, handle, options);
1009
- });
1010
- }
1011
- async click(metadata, selector, options) {
1012
- const controller = new _progress.ProgressController(metadata, this);
1013
- return controller.run(async progress => {
1014
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._click(progress, {
1015
- ...options,
1016
- waitAfter: !options.noWaitAfter
1017
- })));
1018
- }, this._page._timeoutSettings.timeout(options));
1019
- }
1020
- async dblclick(metadata, selector, options = {}) {
1021
- const controller = new _progress.ProgressController(metadata, this);
1022
- return controller.run(async progress => {
1023
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._dblclick(progress, options)));
1024
- }, this._page._timeoutSettings.timeout(options));
1025
- }
1026
- async dragAndDrop(metadata, source, target, options = {}) {
1027
- const controller = new _progress.ProgressController(metadata, this);
1028
- await controller.run(async progress => {
1029
- dom.assertDone(await this._retryWithProgressIfNotConnected(progress, source, options.strict, !options.force /* performLocatorHandlersCheckpoint */, async handle => {
1030
- return handle._retryPointerAction(progress, 'move and down', false, async point => {
1031
- await this._page.mouse.move(point.x, point.y);
1032
- await this._page.mouse.down();
1033
- }, {
1034
- ...options,
1035
- waitAfter: 'disabled',
1036
- position: options.sourcePosition,
1037
- timeout: progress.timeUntilDeadline()
1038
- });
1039
- }));
1040
- // Note: do not perform locator handlers checkpoint to avoid moving the mouse in the middle of a drag operation.
1041
- dom.assertDone(await this._retryWithProgressIfNotConnected(progress, target, options.strict, false /* performLocatorHandlersCheckpoint */, async handle => {
1042
- return handle._retryPointerAction(progress, 'move and up', false, async point => {
1043
- await this._page.mouse.move(point.x, point.y);
1044
- await this._page.mouse.up();
1045
- }, {
1046
- ...options,
1047
- waitAfter: 'disabled',
1048
- position: options.targetPosition,
1049
- timeout: progress.timeUntilDeadline()
1050
- });
1051
- }));
1052
- }, this._page._timeoutSettings.timeout(options));
1053
- }
1054
- async tap(metadata, selector, options) {
1055
- if (!this._page._browserContext._options.hasTouch) throw new Error('The page does not support tap. Use hasTouch context option to enable touch support.');
1056
- const controller = new _progress.ProgressController(metadata, this);
1057
- return controller.run(async progress => {
1058
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._tap(progress, options)));
1059
- }, this._page._timeoutSettings.timeout(options));
1060
- }
1061
- async fill(metadata, selector, value, options) {
1062
- const controller = new _progress.ProgressController(metadata, this);
1063
- return controller.run(async progress => {
1064
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._fill(progress, value, options)));
1065
- }, this._page._timeoutSettings.timeout(options));
1066
- }
1067
- async focus(metadata, selector, options = {}) {
1068
- const controller = new _progress.ProgressController(metadata, this);
1069
- await controller.run(async progress => {
1070
- dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, true /* performLocatorHandlersCheckpoint */, handle => handle._focus(progress)));
1071
- }, this._page._timeoutSettings.timeout(options));
1072
- }
1073
- async blur(metadata, selector, options = {}) {
1074
- const controller = new _progress.ProgressController(metadata, this);
1075
- await controller.run(async progress => {
1076
- dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, true /* performLocatorHandlersCheckpoint */, handle => handle._blur(progress)));
1077
- }, this._page._timeoutSettings.timeout(options));
1078
- }
1079
- async textContent(metadata, selector, options = {}, scope) {
1080
- return this._callOnElementOnceMatches(metadata, selector, (injected, element) => element.textContent, undefined, options, scope);
1081
- }
1082
- async innerText(metadata, selector, options = {}, scope) {
1083
- return this._callOnElementOnceMatches(metadata, selector, (injectedScript, element) => {
1084
- if (element.namespaceURI !== 'http://www.w3.org/1999/xhtml') throw injectedScript.createStacklessError('Node is not an HTMLElement');
1085
- return element.innerText;
1086
- }, undefined, options, scope);
1087
- }
1088
- async innerHTML(metadata, selector, options = {}, scope) {
1089
- return this._callOnElementOnceMatches(metadata, selector, (injected, element) => element.innerHTML, undefined, options, scope);
1090
- }
1091
- async getAttribute(metadata, selector, name, options = {}, scope) {
1092
- return this._callOnElementOnceMatches(metadata, selector, (injected, element, data) => element.getAttribute(data.name), {
1093
- name
1094
- }, options, scope);
1095
- }
1096
- async inputValue(metadata, selector, options = {}, scope) {
1097
- return this._callOnElementOnceMatches(metadata, selector, (injectedScript, node) => {
1098
- const element = injectedScript.retarget(node, 'follow-label');
1099
- if (!element || element.nodeName !== 'INPUT' && element.nodeName !== 'TEXTAREA' && element.nodeName !== 'SELECT') throw injectedScript.createStacklessError('Node is not an <input>, <textarea> or <select> element');
1100
- return element.value;
1101
- }, undefined, options, scope);
1102
- }
1103
- async highlight(selector) {
1104
- const resolved = await this.selectors.resolveInjectedForSelector(selector);
1105
- if (!resolved) return;
1106
- return await resolved.injected.evaluate((injected, {
1107
- info
1108
- }) => {
1109
- return injected.highlight(info.parsed);
1110
- }, {
1111
- info: resolved.info
1112
- });
1113
- }
1114
- async hideHighlight() {
1115
- return this.raceAgainstEvaluationStallingEvents(async () => {
1116
- const context = await this._utilityContext();
1117
- const injectedScript = await context.injectedScript();
1118
- return await injectedScript.evaluate(injected => {
1119
- return injected.hideHighlight();
1120
- });
1121
- });
1122
- }
1123
- async _elementState(metadata, selector, state, options = {}, scope) {
1124
- const result = await this._callOnElementOnceMatches(metadata, selector, (injected, element, data) => {
1125
- return injected.elementState(element, data.state);
1126
- }, {
1127
- state
1128
- }, options, scope);
1129
- return dom.throwRetargetableDOMError(result);
1130
- }
1131
- async isVisible(metadata, selector, options = {}, scope) {
1132
- const controller = new _progress.ProgressController(metadata, this);
1133
- return controller.run(async progress => {
1134
- progress.log(` checking visibility of ${this._asLocator(selector)}`);
1135
- return await this.isVisibleInternal(selector, options, scope);
1136
- }, this._page._timeoutSettings.timeout({}));
1137
- }
1138
- async isVisibleInternal(selector, options = {}, scope) {
1139
- try {
1140
- const resolved = await this.selectors.resolveInjectedForSelector(selector, options, scope);
1141
- if (!resolved) return false;
1142
- return await resolved.injected.evaluate((injected, {
1143
- info,
1144
- root
1145
- }) => {
1146
- const element = injected.querySelector(info.parsed, root || document, info.strict);
1147
- const state = element ? injected.elementState(element, 'visible') : false;
1148
- return state === 'error:notconnected' ? false : state;
1149
- }, {
1150
- info: resolved.info,
1151
- root: resolved.frame === this ? scope : undefined
1152
- });
1153
- } catch (e) {
1154
- if (js.isJavaScriptErrorInEvaluate(e) || (0, _selectorParser.isInvalidSelectorError)(e) || (0, _protocolError.isSessionClosedError)(e)) throw e;
1155
- return false;
1156
- }
1157
- }
1158
- async isHidden(metadata, selector, options = {}, scope) {
1159
- return !(await this.isVisible(metadata, selector, options, scope));
1160
- }
1161
- async isDisabled(metadata, selector, options = {}, scope) {
1162
- return this._elementState(metadata, selector, 'disabled', options, scope);
1163
- }
1164
- async isEnabled(metadata, selector, options = {}, scope) {
1165
- return this._elementState(metadata, selector, 'enabled', options, scope);
1166
- }
1167
- async isEditable(metadata, selector, options = {}, scope) {
1168
- return this._elementState(metadata, selector, 'editable', options, scope);
1169
- }
1170
- async isChecked(metadata, selector, options = {}, scope) {
1171
- return this._elementState(metadata, selector, 'checked', options, scope);
1172
- }
1173
- async hover(metadata, selector, options = {}) {
1174
- const controller = new _progress.ProgressController(metadata, this);
1175
- return controller.run(async progress => {
1176
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._hover(progress, options)));
1177
- }, this._page._timeoutSettings.timeout(options));
1178
- }
1179
- async selectOption(metadata, selector, elements, values, options = {}) {
1180
- const controller = new _progress.ProgressController(metadata, this);
1181
- return controller.run(async progress => {
1182
- return await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._selectOption(progress, elements, values, options));
1183
- }, this._page._timeoutSettings.timeout(options));
1184
- }
1185
- async setInputFiles(metadata, selector, params) {
1186
- const inputFileItems = await (0, _fileUploadUtils.prepareFilesForUpload)(this, params);
1187
- const controller = new _progress.ProgressController(metadata, this);
1188
- return controller.run(async progress => {
1189
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, params.strict, true /* performLocatorHandlersCheckpoint */, handle => handle._setInputFiles(progress, inputFileItems)));
1190
- }, this._page._timeoutSettings.timeout(params));
1191
- }
1192
- async type(metadata, selector, text, options = {}) {
1193
- const controller = new _progress.ProgressController(metadata, this);
1194
- return controller.run(async progress => {
1195
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, true /* performLocatorHandlersCheckpoint */, handle => handle._type(progress, text, options)));
1196
- }, this._page._timeoutSettings.timeout(options));
1197
- }
1198
- async press(metadata, selector, key, options = {}) {
1199
- const controller = new _progress.ProgressController(metadata, this);
1200
- return controller.run(async progress => {
1201
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, true /* performLocatorHandlersCheckpoint */, handle => handle._press(progress, key, options)));
1202
- }, this._page._timeoutSettings.timeout(options));
1203
- }
1204
- async check(metadata, selector, options = {}) {
1205
- const controller = new _progress.ProgressController(metadata, this);
1206
- return controller.run(async progress => {
1207
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._setChecked(progress, true, options)));
1208
- }, this._page._timeoutSettings.timeout(options));
1209
- }
1210
- async uncheck(metadata, selector, options = {}) {
1211
- const controller = new _progress.ProgressController(metadata, this);
1212
- return controller.run(async progress => {
1213
- return dom.assertDone(await this._retryWithProgressIfNotConnected(progress, selector, options.strict, !options.force /* performLocatorHandlersCheckpoint */, handle => handle._setChecked(progress, false, options)));
1214
- }, this._page._timeoutSettings.timeout(options));
1215
- }
1216
- async waitForTimeout(metadata, timeout) {
1217
- const controller = new _progress.ProgressController(metadata, this);
1218
- return controller.run(async () => {
1219
- await new Promise(resolve => setTimeout(resolve, timeout));
1220
- });
1221
- }
1222
- async expect(metadata, selector, options) {
1223
- const result = await this._expectImpl(metadata, selector, options);
1224
- // Library mode special case for the expect errors which are return values, not exceptions.
1225
- if (result.matches === options.isNot) metadata.error = {
1226
- error: {
1227
- name: 'Expect',
1228
- message: 'Expect failed'
1229
- }
1230
- };
1231
- return result;
1232
- }
1233
- async _expectImpl(metadata, selector, options) {
1234
- const lastIntermediateResult = {
1235
- isSet: false
1236
- };
1237
- try {
1238
- let timeout = this._page._timeoutSettings.timeout(options);
1239
- const start = timeout > 0 ? (0, _utils.monotonicTime)() : 0;
1240
-
1241
- // Step 1: perform locator handlers checkpoint with a specified timeout.
1242
- await new _progress.ProgressController(metadata, this).run(async progress => {
1243
- progress.log(`${metadata.apiName}${timeout ? ` with timeout ${timeout}ms` : ''}`);
1244
- progress.log(`waiting for ${this._asLocator(selector)}`);
1245
- await this._page.performLocatorHandlersCheckpoint(progress);
1246
- }, timeout);
1247
-
1248
- // Step 2: perform one-shot expect check without a timeout.
1249
- // Supports the case of `expect(locator).toBeVisible({ timeout: 1 })`
1250
- // that should succeed when the locator is already visible.
1251
- try {
1252
- const resultOneShot = await new _progress.ProgressController(metadata, this).run(async progress => {
1253
- return await this._expectInternal(progress, selector, options, lastIntermediateResult);
1254
- });
1255
- if (resultOneShot.matches !== options.isNot) return resultOneShot;
1256
- } catch (e) {
1257
- if (js.isJavaScriptErrorInEvaluate(e) || (0, _selectorParser.isInvalidSelectorError)(e)) throw e;
1258
- // Ignore any other errors from one-shot, we'll handle them during retries.
1259
- }
1260
- if (timeout > 0) {
1261
- const elapsed = (0, _utils.monotonicTime)() - start;
1262
- timeout -= elapsed;
1263
- }
1264
- if (timeout < 0) return {
1265
- matches: options.isNot,
1266
- log: metadata.log,
1267
- timedOut: true,
1268
- received: lastIntermediateResult.received
1269
- };
1270
-
1271
- // Step 3: auto-retry expect with increasing timeouts. Bounded by the total remaining time.
1272
- return await new _progress.ProgressController(metadata, this).run(async progress => {
1273
- return await this.retryWithProgressAndTimeouts(progress, [100, 250, 500, 1000], async continuePolling => {
1274
- await this._page.performLocatorHandlersCheckpoint(progress);
1275
- const {
1276
- matches,
1277
- received
1278
- } = await this._expectInternal(progress, selector, options, lastIntermediateResult);
1279
- if (matches === options.isNot) {
1280
- // Keep waiting in these cases:
1281
- // expect(locator).conditionThatDoesNotMatch
1282
- // expect(locator).not.conditionThatDoesMatch
1283
- return continuePolling;
1284
- }
1285
- return {
1286
- matches,
1287
- received
1288
- };
1289
- });
1290
- }, timeout);
1291
- } catch (e) {
1292
- // Q: Why not throw upon isSessionClosedError(e) as in other places?
1293
- // A: We want user to receive a friendly message containing the last intermediate result.
1294
- if (js.isJavaScriptErrorInEvaluate(e) || (0, _selectorParser.isInvalidSelectorError)(e)) throw e;
1295
- const result = {
1296
- matches: options.isNot,
1297
- log: metadata.log
1298
- };
1299
- if (lastIntermediateResult.isSet) result.received = lastIntermediateResult.received;
1300
- if (e instanceof _errors.TimeoutError) result.timedOut = true;
1301
- return result;
1302
- }
1303
- }
1304
- async _expectInternal(progress, selector, options, lastIntermediateResult) {
1305
- var _info$world;
1306
- const selectorInFrame = await this.selectors.resolveFrameForSelector(selector, {
1307
- strict: true
1308
- });
1309
- progress.throwIfAborted();
1310
- const {
1311
- frame,
1312
- info
1313
- } = selectorInFrame || {
1314
- frame: this,
1315
- info: undefined
1316
- };
1317
- const world = options.expression === 'to.have.property' ? 'main' : (_info$world = info === null || info === void 0 ? void 0 : info.world) !== null && _info$world !== void 0 ? _info$world : 'utility';
1318
- const context = await frame._context(world);
1319
- const injected = await context.injectedScript();
1320
- progress.throwIfAborted();
1321
- const {
1322
- log,
1323
- matches,
1324
- received,
1325
- missingReceived
1326
- } = await injected.evaluate(async (injected, {
1327
- info,
1328
- options,
1329
- callId
1330
- }) => {
1331
- const elements = info ? injected.querySelectorAll(info.parsed, document) : [];
1332
- const isArray = options.expression === 'to.have.count' || options.expression.endsWith('.array');
1333
- let log = '';
1334
- if (isArray) log = ` locator resolved to ${elements.length} element${elements.length === 1 ? '' : 's'}`;else if (elements.length > 1) throw injected.strictModeViolationError(info.parsed, elements);else if (elements.length) log = ` locator resolved to ${injected.previewNode(elements[0])}`;
1335
- if (callId) injected.markTargetElements(new Set(elements), callId);
1336
- return {
1337
- log,
1338
- ...(await injected.expect(elements[0], options, elements))
1339
- };
1340
- }, {
1341
- info,
1342
- options,
1343
- callId: progress.metadata.id
1344
- });
1345
- if (log) progress.log(log);
1346
- // Note: missingReceived avoids `unexpected value "undefined"` when element was not found.
1347
- if (matches === options.isNot) {
1348
- lastIntermediateResult.received = missingReceived ? '<element(s) not found>' : received;
1349
- lastIntermediateResult.isSet = true;
1350
- if (!missingReceived && !Array.isArray(received)) progress.log(` unexpected value "${renderUnexpectedValue(options.expression, received)}"`);
1351
- }
1352
- return {
1353
- matches,
1354
- received
1355
- };
1356
- }
1357
- async _waitForFunctionExpression(metadata, expression, isFunction, arg, options, world = 'main') {
1358
- const controller = new _progress.ProgressController(metadata, this);
1359
- if (typeof options.pollingInterval === 'number') (0, _utils.assert)(options.pollingInterval > 0, 'Cannot poll with non-positive interval: ' + options.pollingInterval);
1360
- expression = js.normalizeEvaluationExpression(expression, isFunction);
1361
- return controller.run(async progress => {
1362
- return this.retryWithProgressAndTimeouts(progress, [100], async () => {
1363
- const context = world === 'main' ? await this._mainContext() : await this._utilityContext();
1364
- const injectedScript = await context.injectedScript();
1365
- const handle = await injectedScript.evaluateHandle((injected, {
1366
- expression,
1367
- isFunction,
1368
- polling,
1369
- arg
1370
- }) => {
1371
- const predicate = () => {
1372
- // NOTE: make sure to use `globalThis.eval` instead of `self.eval` due to a bug with sandbox isolation
1373
- // in firefox.
1374
- // See https://bugzilla.mozilla.org/show_bug.cgi?id=1814898
1375
- let result = globalThis.eval(expression);
1376
- if (isFunction === true) {
1377
- result = result(arg);
1378
- } else if (isFunction === false) {
1379
- result = result;
1380
- } else {
1381
- // auto detect.
1382
- if (typeof result === 'function') result = result(arg);
1383
- }
1384
- return result;
1385
- };
1386
- let fulfill;
1387
- let reject;
1388
- let aborted = false;
1389
- const result = new Promise((f, r) => {
1390
- fulfill = f;
1391
- reject = r;
1392
- });
1393
- const next = () => {
1394
- if (aborted) return;
1395
- try {
1396
- const success = predicate();
1397
- if (success) {
1398
- fulfill(success);
1399
- return;
1400
- }
1401
- if (typeof polling !== 'number') injected.builtinRequestAnimationFrame(next);else injected.builtinSetTimeout(next, polling);
1402
- } catch (e) {
1403
- reject(e);
1404
- }
1405
- };
1406
- next();
1407
- return {
1408
- result,
1409
- abort: () => aborted = true
1410
- };
1411
- }, {
1412
- expression,
1413
- isFunction,
1414
- polling: options.pollingInterval,
1415
- arg
1416
- });
1417
- progress.cleanupWhenAborted(() => handle.evaluate(h => h.abort()).catch(() => {}));
1418
- return handle.evaluateHandle(h => h.result);
1419
- });
1420
- }, this._page._timeoutSettings.timeout(options));
1421
- }
1422
- async waitForFunctionValueInUtility(progress, pageFunction) {
1423
- const expression = `() => {
1424
- const result = (${pageFunction})();
1425
- if (!result)
1426
- return result;
1427
- return JSON.stringify(result);
1428
- }`;
1429
- const handle = await this._waitForFunctionExpression((0, _instrumentation.serverSideCallMetadata)(), expression, true, undefined, {
1430
- timeout: progress.timeUntilDeadline()
1431
- }, 'utility');
1432
- return JSON.parse(handle.rawValue());
1433
- }
1434
- async title() {
1435
- const context = await this._utilityContext();
1436
- return context.evaluate(() => document.title);
1437
- }
1438
- async rafrafTimeout(timeout) {
1439
- if (timeout === 0) return;
1440
- const context = await this._utilityContext();
1441
- await Promise.all([
1442
- // wait for double raf
1443
- context.evaluate(() => new Promise(x => {
1444
- requestAnimationFrame(() => {
1445
- requestAnimationFrame(x);
1446
- });
1447
- })), new Promise(fulfill => setTimeout(fulfill, timeout))]);
1448
- }
1449
- _onDetached() {
1450
- this._stopNetworkIdleTimer();
1451
- this._detachedScope.close(new Error('Frame was detached'));
1452
- for (const data of this._contextData.values()) {
1453
- if (data.context) data.context.contextDestroyed('Frame was detached');
1454
- data.contextPromise.resolve({
1455
- destroyedReason: 'Frame was detached'
1456
- });
1457
- }
1458
- if (this._parentFrame) this._parentFrame._childFrames.delete(this);
1459
- this._parentFrame = null;
1460
- }
1461
- async _callOnElementOnceMatches(metadata, selector, body, taskData, options = {}, scope) {
1462
- const callbackText = body.toString();
1463
- const controller = new _progress.ProgressController(metadata, this);
1464
- return controller.run(async progress => {
1465
- progress.log(`waiting for ${this._asLocator(selector)}`);
1466
- const promise = this.retryWithProgressAndTimeouts(progress, [0, 20, 50, 100, 100, 500], async continuePolling => {
1467
- const resolved = await this.selectors.resolveInjectedForSelector(selector, options, scope);
1468
- progress.throwIfAborted();
1469
- if (!resolved) return continuePolling;
1470
- const {
1471
- log,
1472
- success,
1473
- value
1474
- } = await resolved.injected.evaluate((injected, {
1475
- info,
1476
- callbackText,
1477
- taskData,
1478
- callId,
1479
- root
1480
- }) => {
1481
- const callback = injected.eval(callbackText);
1482
- const element = injected.querySelector(info.parsed, root || document, info.strict);
1483
- if (!element) return {
1484
- success: false
1485
- };
1486
- const log = ` locator resolved to ${injected.previewNode(element)}`;
1487
- if (callId) injected.markTargetElements(new Set([element]), callId);
1488
- return {
1489
- log,
1490
- success: true,
1491
- value: callback(injected, element, taskData)
1492
- };
1493
- }, {
1494
- info: resolved.info,
1495
- callbackText,
1496
- taskData,
1497
- callId: progress.metadata.id,
1498
- root: resolved.frame === this ? scope : undefined
1499
- });
1500
- if (log) progress.log(log);
1501
- if (!success) return continuePolling;
1502
- return value;
1503
- });
1504
- return scope ? scope._context._raceAgainstContextDestroyed(promise) : promise;
1505
- }, this._page._timeoutSettings.timeout(options));
1506
- }
1507
- _setContext(world, context) {
1508
- const data = this._contextData.get(world);
1509
- data.context = context;
1510
- if (context) data.contextPromise.resolve(context);else data.contextPromise = new _manualPromise.ManualPromise();
1511
- }
1512
- _contextCreated(world, context) {
1513
- const data = this._contextData.get(world);
1514
- // In case of multiple sessions to the same target, there's a race between
1515
- // connections so we might end up creating multiple isolated worlds.
1516
- // We can use either.
1517
- if (data.context) {
1518
- data.context.contextDestroyed('Execution context was destroyed, most likely because of a navigation');
1519
- this._setContext(world, null);
1520
- }
1521
- this._setContext(world, context);
1522
- }
1523
- _contextDestroyed(context) {
1524
- // Sometimes we get this after detach, in which case we should not reset
1525
- // our already destroyed contexts to something that will never resolve.
1526
- if (this._detachedScope.isClosed()) return;
1527
- context.contextDestroyed('Execution context was destroyed, most likely because of a navigation');
1528
- for (const [world, data] of this._contextData) {
1529
- if (data.context === context) this._setContext(world, null);
1530
- }
1531
- }
1532
- _startNetworkIdleTimer() {
1533
- (0, _utils.assert)(!this._networkIdleTimer);
1534
- // We should not start a timer and report networkidle in detached frames.
1535
- // This happens at least in Firefox for child frames, where we may get requestFinished
1536
- // after the frame was detached - probably a race in the Firefox itself.
1537
- if (this._firedLifecycleEvents.has('networkidle') || this._detachedScope.isClosed()) return;
1538
- this._networkIdleTimer = setTimeout(() => {
1539
- this._firedNetworkIdleSelf = true;
1540
- this._page.mainFrame()._recalculateNetworkIdle();
1541
- }, 500);
1542
- }
1543
- _stopNetworkIdleTimer() {
1544
- if (this._networkIdleTimer) clearTimeout(this._networkIdleTimer);
1545
- this._networkIdleTimer = undefined;
1546
- this._firedNetworkIdleSelf = false;
1547
- }
1548
- async extendInjectedScript(source, arg) {
1549
- const context = await this._context('main');
1550
- const injectedScriptHandle = await context.injectedScript();
1551
- return injectedScriptHandle.evaluateHandle((injectedScript, {
1552
- source,
1553
- arg
1554
- }) => {
1555
- return injectedScript.extend(source, arg);
1556
- }, {
1557
- source,
1558
- arg
1559
- });
1560
- }
1561
- async resetStorageForCurrentOriginBestEffort(newStorage) {
1562
- const context = await this._utilityContext();
1563
- await context.evaluate(async ({
1564
- ls
1565
- }) => {
1566
- // Clean DOMStorage.
1567
- sessionStorage.clear();
1568
- localStorage.clear();
1569
-
1570
- // Add new DOM Storage values.
1571
- for (const entry of ls || []) localStorage[entry.name] = entry.value;
1572
-
1573
- // Clean Service Workers
1574
- const registrations = navigator.serviceWorker ? await navigator.serviceWorker.getRegistrations() : [];
1575
- await Promise.all(registrations.map(async r => {
1576
- // Heuristic for service workers that stalled during main script fetch or importScripts:
1577
- // Waiting for them to finish unregistering takes ages so we do not await.
1578
- // However, they will unregister immediately after fetch finishes and should not affect next page load.
1579
- // Unfortunately, loading next page in Chromium still takes 5 seconds waiting for
1580
- // some operation on this bogus service worker to finish.
1581
- if (!r.installing && !r.waiting && !r.active) r.unregister().catch(() => {});else await r.unregister().catch(() => {});
1582
- }));
1583
-
1584
- // Clean IndexedDB
1585
- for (const db of (await ((_indexedDB$databases = (_indexedDB = indexedDB).databases) === null || _indexedDB$databases === void 0 ? void 0 : _indexedDB$databases.call(_indexedDB))) || []) {
1586
- var _indexedDB$databases, _indexedDB;
1587
- // Do not wait for the callback - it is called on timer in Chromium (slow).
1588
- if (db.name) indexedDB.deleteDatabase(db.name);
1589
- }
1590
- }, {
1591
- ls: newStorage === null || newStorage === void 0 ? void 0 : newStorage.localStorage
1592
- }).catch(() => {});
1593
- }
1594
- _asLocator(selector) {
1595
- return (0, _utils.asLocator)(this._page.attribution.playwright.options.sdkLanguage, selector);
1596
- }
1597
- }
1598
- exports.Frame = Frame;
1599
- Frame.Events = {
1600
- InternalNavigation: 'internalnavigation',
1601
- AddLifecycle: 'addlifecycle',
1602
- RemoveLifecycle: 'removelifecycle'
1603
- };
1604
- class SignalBarrier {
1605
- constructor(progress) {
1606
- this._progress = void 0;
1607
- this._protectCount = 0;
1608
- this._promise = new _manualPromise.ManualPromise();
1609
- this._progress = progress;
1610
- this.retain();
1611
- }
1612
- waitFor() {
1613
- this.release();
1614
- return this._promise;
1615
- }
1616
- async addFrameNavigation(frame) {
1617
- // Auto-wait top-level navigations only.
1618
- if (frame.parentFrame()) return;
1619
- this.retain();
1620
- const waiter = _helper.helper.waitForEvent(null, frame, Frame.Events.InternalNavigation, e => {
1621
- if (!e.isPublic) return false;
1622
- if (!e.error && this._progress) this._progress.log(` navigated to "${frame._url}"`);
1623
- return true;
1624
- });
1625
- await _utils.LongStandingScope.raceMultiple([frame._page.openScope, frame._detachedScope], waiter.promise).catch(() => {});
1626
- waiter.dispose();
1627
- this.release();
1628
- }
1629
- retain() {
1630
- ++this._protectCount;
1631
- }
1632
- release() {
1633
- --this._protectCount;
1634
- if (!this._protectCount) this._promise.resolve();
1635
- }
1636
- }
1637
- function verifyLifecycle(name, waitUntil) {
1638
- if (waitUntil === 'networkidle0') waitUntil = 'networkidle';
1639
- if (!types.kLifecycleEvents.has(waitUntil)) throw new Error(`${name}: expected one of (load|domcontentloaded|networkidle|commit)`);
1640
- return waitUntil;
1641
- }
1642
- function renderUnexpectedValue(expression, received) {
1643
- if (expression === 'to.be.checked') return received ? 'checked' : 'unchecked';
1644
- if (expression === 'to.be.unchecked') return received ? 'unchecked' : 'checked';
1645
- if (expression === 'to.be.visible') return received ? 'visible' : 'hidden';
1646
- if (expression === 'to.be.hidden') return received ? 'hidden' : 'visible';
1647
- if (expression === 'to.be.enabled') return received ? 'enabled' : 'disabled';
1648
- if (expression === 'to.be.disabled') return received ? 'disabled' : 'enabled';
1649
- if (expression === 'to.be.editable') return received ? 'editable' : 'readonly';
1650
- if (expression === 'to.be.readonly') return received ? 'readonly' : 'editable';
1651
- if (expression === 'to.be.empty') return received ? 'empty' : 'not empty';
1652
- if (expression === 'to.be.focused') return received ? 'focused' : 'not focused';
1653
- return received;
1654
- }