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,147 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.TaskRunner = void 0;
7
- var _utilsBundle = require("playwright-core/lib/utilsBundle");
8
- var _utils = require("playwright-core/lib/utils");
9
- var _sigIntWatcher = require("./sigIntWatcher");
10
- var _util = require("../util");
11
- /**
12
- * Copyright (c) Microsoft Corporation.
13
- *
14
- * Licensed under the Apache License, Version 2.0 (the "License");
15
- * you may not use this file except in compliance with the License.
16
- * You may obtain a copy of the License at
17
- *
18
- * http://www.apache.org/licenses/LICENSE-2.0
19
- *
20
- * Unless required by applicable law or agreed to in writing, software
21
- * distributed under the License is distributed on an "AS IS" BASIS,
22
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
23
- * See the License for the specific language governing permissions and
24
- * limitations under the License.
25
- */
26
-
27
- class TaskRunner {
28
- static create(reporter, globalTimeoutForError = 0) {
29
- return new TaskRunner(reporter, globalTimeoutForError);
30
- }
31
- constructor(reporter, globalTimeoutForError) {
32
- this._tasks = [];
33
- this._reporter = void 0;
34
- this._hasErrors = false;
35
- this._interrupted = false;
36
- this._isTearDown = false;
37
- this._globalTimeoutForError = void 0;
38
- this._reporter = reporter;
39
- this._globalTimeoutForError = globalTimeoutForError;
40
- }
41
- addTask(name, task) {
42
- this._tasks.push({
43
- name,
44
- task
45
- });
46
- }
47
- async run(context, deadline, cancelPromise) {
48
- const {
49
- status,
50
- cleanup
51
- } = await this.runDeferCleanup(context, deadline, cancelPromise);
52
- const teardownStatus = await cleanup();
53
- return status === 'passed' ? teardownStatus : status;
54
- }
55
- async runDeferCleanup(context, deadline, cancelPromise = new _utils.ManualPromise()) {
56
- const sigintWatcher = new _sigIntWatcher.SigIntWatcher();
57
- const timeoutWatcher = new TimeoutWatcher(deadline);
58
- const teardownRunner = new TaskRunner(this._reporter, this._globalTimeoutForError);
59
- teardownRunner._isTearDown = true;
60
- let currentTaskName;
61
- const taskLoop = async () => {
62
- for (const {
63
- name,
64
- task
65
- } of this._tasks) {
66
- currentTaskName = name;
67
- if (this._interrupted) break;
68
- (0, _utilsBundle.debug)('pw:test:task')(`"${name}" started`);
69
- const errors = [];
70
- const softErrors = [];
71
- try {
72
- var _task$setup;
73
- teardownRunner._tasks.unshift({
74
- name: `teardown for ${name}`,
75
- task: {
76
- setup: task.teardown
77
- }
78
- });
79
- await ((_task$setup = task.setup) === null || _task$setup === void 0 ? void 0 : _task$setup.call(task, this._reporter, context, errors, softErrors));
80
- } catch (e) {
81
- (0, _utilsBundle.debug)('pw:test:task')(`error in "${name}": `, e);
82
- errors.push((0, _util.serializeError)(e));
83
- } finally {
84
- for (const error of [...softErrors, ...errors]) {
85
- var _this$_reporter$onErr, _this$_reporter;
86
- (_this$_reporter$onErr = (_this$_reporter = this._reporter).onError) === null || _this$_reporter$onErr === void 0 || _this$_reporter$onErr.call(_this$_reporter, error);
87
- }
88
- if (errors.length) {
89
- if (!this._isTearDown) this._interrupted = true;
90
- this._hasErrors = true;
91
- }
92
- }
93
- (0, _utilsBundle.debug)('pw:test:task')(`"${name}" finished`);
94
- }
95
- };
96
- await Promise.race([taskLoop(), cancelPromise, sigintWatcher.promise(), timeoutWatcher.promise]);
97
- sigintWatcher.disarm();
98
- timeoutWatcher.disarm();
99
-
100
- // Prevent subsequent tasks from running.
101
- this._interrupted = true;
102
- let status = 'passed';
103
- if (sigintWatcher.hadSignal() || cancelPromise !== null && cancelPromise !== void 0 && cancelPromise.isDone()) {
104
- status = 'interrupted';
105
- } else if (timeoutWatcher.timedOut()) {
106
- var _this$_reporter$onErr2, _this$_reporter2;
107
- (_this$_reporter$onErr2 = (_this$_reporter2 = this._reporter).onError) === null || _this$_reporter$onErr2 === void 0 || _this$_reporter$onErr2.call(_this$_reporter2, {
108
- message: _utilsBundle.colors.red(`Timed out waiting ${this._globalTimeoutForError / 1000}s for the ${currentTaskName} to run`)
109
- });
110
- status = 'timedout';
111
- } else if (this._hasErrors) {
112
- status = 'failed';
113
- }
114
- cancelPromise === null || cancelPromise === void 0 || cancelPromise.resolve();
115
- // Note that upon hitting deadline, we "run cleanup", but it exits immediately
116
- // because of the same deadline. Essentially, we're not performing any cleanup.
117
- const cleanup = () => teardownRunner.runDeferCleanup(context, deadline).then(r => r.status);
118
- return {
119
- status,
120
- cleanup
121
- };
122
- }
123
- }
124
- exports.TaskRunner = TaskRunner;
125
- class TimeoutWatcher {
126
- constructor(deadline) {
127
- this._timedOut = false;
128
- this.promise = new _utils.ManualPromise();
129
- this._timer = void 0;
130
- if (!deadline) return;
131
- if (deadline - (0, _utils.monotonicTime)() <= 0) {
132
- this._timedOut = true;
133
- this.promise.resolve();
134
- return;
135
- }
136
- this._timer = setTimeout(() => {
137
- this._timedOut = true;
138
- this.promise.resolve();
139
- }, deadline - (0, _utils.monotonicTime)());
140
- }
141
- timedOut() {
142
- return this._timedOut;
143
- }
144
- disarm() {
145
- clearTimeout(this._timer);
146
- }
147
- }
@@ -1,407 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.TestRun = void 0;
7
- exports.createTaskRunner = createTaskRunner;
8
- exports.createTaskRunnerForDevServer = createTaskRunnerForDevServer;
9
- exports.createTaskRunnerForList = createTaskRunnerForList;
10
- exports.createTaskRunnerForListFiles = createTaskRunnerForListFiles;
11
- exports.createTaskRunnerForTestServer = createTaskRunnerForTestServer;
12
- exports.createTaskRunnerForWatchSetup = createTaskRunnerForWatchSetup;
13
- var _fs = _interopRequireDefault(require("fs"));
14
- var _path = _interopRequireDefault(require("path"));
15
- var _util = require("util");
16
- var _utilsBundle = require("playwright-core/lib/utilsBundle");
17
- var _utils = require("playwright-core/lib/utils");
18
- var _dispatcher = require("./dispatcher");
19
- var _testGroups = require("../runner/testGroups");
20
- var _taskRunner = require("./taskRunner");
21
- var _loadUtils = require("./loadUtils");
22
- var _test = require("../common/test");
23
- var _projectUtils = require("./projectUtils");
24
- var _failureTracker = require("./failureTracker");
25
- var _vcs = require("./vcs");
26
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
27
- /**
28
- * Copyright Microsoft Corporation. All rights reserved.
29
- *
30
- * Licensed under the Apache License, Version 2.0 (the "License");
31
- * you may not use this file except in compliance with the License.
32
- * You may obtain a copy of the License at
33
- *
34
- * http://www.apache.org/licenses/LICENSE-2.0
35
- *
36
- * Unless required by applicable law or agreed to in writing, software
37
- * distributed under the License is distributed on an "AS IS" BASIS,
38
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
39
- * See the License for the specific language governing permissions and
40
- * limitations under the License.
41
- */
42
-
43
- const readDirAsync = (0, _util.promisify)(_fs.default.readdir);
44
- class TestRun {
45
- constructor(config) {
46
- this.config = void 0;
47
- this.failureTracker = void 0;
48
- this.rootSuite = undefined;
49
- this.phases = [];
50
- this.projectFiles = new Map();
51
- this.projectSuites = new Map();
52
- this.config = config;
53
- this.failureTracker = new _failureTracker.FailureTracker(config);
54
- }
55
- }
56
- exports.TestRun = TestRun;
57
- function createTaskRunner(config, reporter) {
58
- const taskRunner = _taskRunner.TaskRunner.create(reporter, config.config.globalTimeout);
59
- addGlobalSetupTasks(taskRunner, config);
60
- taskRunner.addTask('load tests', createLoadTask('in-process', {
61
- filterOnly: true,
62
- failOnLoadErrors: true
63
- }));
64
- addRunTasks(taskRunner, config);
65
- return taskRunner;
66
- }
67
- function createTaskRunnerForWatchSetup(config, reporter) {
68
- const taskRunner = _taskRunner.TaskRunner.create(reporter);
69
- addGlobalSetupTasks(taskRunner, config);
70
- return taskRunner;
71
- }
72
- function createTaskRunnerForTestServer(config, reporter) {
73
- const taskRunner = _taskRunner.TaskRunner.create(reporter);
74
- taskRunner.addTask('load tests', createLoadTask('out-of-process', {
75
- filterOnly: true,
76
- failOnLoadErrors: false,
77
- doNotRunDepsOutsideProjectFilter: true
78
- }));
79
- addRunTasks(taskRunner, config);
80
- return taskRunner;
81
- }
82
- function addGlobalSetupTasks(taskRunner, config) {
83
- if (!config.configCLIOverrides.preserveOutputDir && !process.env.PW_TEST_NO_REMOVE_OUTPUT_DIRS) taskRunner.addTask('clear output', createRemoveOutputDirsTask());
84
- for (const plugin of config.plugins) taskRunner.addTask('plugin setup', createPluginSetupTask(plugin));
85
- if (config.config.globalSetup || config.config.globalTeardown) taskRunner.addTask('global setup', createGlobalSetupTask());
86
- }
87
- function addRunTasks(taskRunner, config) {
88
- taskRunner.addTask('create phases', createPhasesTask());
89
- taskRunner.addTask('report begin', createReportBeginTask());
90
- for (const plugin of config.plugins) taskRunner.addTask('plugin begin', createPluginBeginTask(plugin));
91
- taskRunner.addTask('test suite', createRunTestsTask());
92
- return taskRunner;
93
- }
94
- function createTaskRunnerForList(config, reporter, mode, options) {
95
- const taskRunner = _taskRunner.TaskRunner.create(reporter, config.config.globalTimeout);
96
- taskRunner.addTask('load tests', createLoadTask(mode, {
97
- ...options,
98
- filterOnly: false
99
- }));
100
- taskRunner.addTask('report begin', createReportBeginTask());
101
- return taskRunner;
102
- }
103
- function createTaskRunnerForListFiles(config, reporter) {
104
- const taskRunner = _taskRunner.TaskRunner.create(reporter, config.config.globalTimeout);
105
- taskRunner.addTask('load tests', createListFilesTask());
106
- taskRunner.addTask('report begin', createReportBeginTask());
107
- return taskRunner;
108
- }
109
- function createTaskRunnerForDevServer(config, reporter, mode, setupAndWait) {
110
- const taskRunner = _taskRunner.TaskRunner.create(reporter, config.config.globalTimeout);
111
- if (setupAndWait) {
112
- for (const plugin of config.plugins) taskRunner.addTask('plugin setup', createPluginSetupTask(plugin));
113
- }
114
- taskRunner.addTask('load tests', createLoadTask(mode, {
115
- failOnLoadErrors: true,
116
- filterOnly: false
117
- }));
118
- taskRunner.addTask('start dev server', createStartDevServerTask());
119
- if (setupAndWait) {
120
- taskRunner.addTask('wait until interrupted', {
121
- setup: async () => new Promise(() => {})
122
- });
123
- }
124
- return taskRunner;
125
- }
126
- function createReportBeginTask() {
127
- return {
128
- setup: async (reporter, {
129
- rootSuite
130
- }) => {
131
- reporter.onBegin(rootSuite);
132
- },
133
- teardown: async ({}) => {}
134
- };
135
- }
136
- function createPluginSetupTask(plugin) {
137
- return {
138
- setup: async (reporter, {
139
- config
140
- }) => {
141
- var _plugin$instance, _plugin$instance$setu;
142
- if (typeof plugin.factory === 'function') plugin.instance = await plugin.factory();else plugin.instance = plugin.factory;
143
- await ((_plugin$instance = plugin.instance) === null || _plugin$instance === void 0 || (_plugin$instance$setu = _plugin$instance.setup) === null || _plugin$instance$setu === void 0 ? void 0 : _plugin$instance$setu.call(_plugin$instance, config.config, config.configDir, reporter));
144
- },
145
- teardown: async () => {
146
- var _plugin$instance2, _plugin$instance2$tea;
147
- await ((_plugin$instance2 = plugin.instance) === null || _plugin$instance2 === void 0 || (_plugin$instance2$tea = _plugin$instance2.teardown) === null || _plugin$instance2$tea === void 0 ? void 0 : _plugin$instance2$tea.call(_plugin$instance2));
148
- }
149
- };
150
- }
151
- function createPluginBeginTask(plugin) {
152
- return {
153
- setup: async (reporter, {
154
- rootSuite
155
- }) => {
156
- var _plugin$instance3, _plugin$instance3$beg;
157
- await ((_plugin$instance3 = plugin.instance) === null || _plugin$instance3 === void 0 || (_plugin$instance3$beg = _plugin$instance3.begin) === null || _plugin$instance3$beg === void 0 ? void 0 : _plugin$instance3$beg.call(_plugin$instance3, rootSuite));
158
- },
159
- teardown: async () => {
160
- var _plugin$instance4, _plugin$instance4$end;
161
- await ((_plugin$instance4 = plugin.instance) === null || _plugin$instance4 === void 0 || (_plugin$instance4$end = _plugin$instance4.end) === null || _plugin$instance4$end === void 0 ? void 0 : _plugin$instance4$end.call(_plugin$instance4));
162
- }
163
- };
164
- }
165
- function createGlobalSetupTask() {
166
- let globalSetupResult;
167
- let globalSetupFinished = false;
168
- let teardownHook;
169
- return {
170
- setup: async (reporter, {
171
- config
172
- }) => {
173
- const setupHook = config.config.globalSetup ? await (0, _loadUtils.loadGlobalHook)(config, config.config.globalSetup) : undefined;
174
- teardownHook = config.config.globalTeardown ? await (0, _loadUtils.loadGlobalHook)(config, config.config.globalTeardown) : undefined;
175
- globalSetupResult = setupHook ? await setupHook(config.config) : undefined;
176
- globalSetupFinished = true;
177
- },
178
- teardown: async (reporter, {
179
- config
180
- }) => {
181
- var _teardownHook;
182
- if (typeof globalSetupResult === 'function') await globalSetupResult();
183
- if (globalSetupFinished) await ((_teardownHook = teardownHook) === null || _teardownHook === void 0 ? void 0 : _teardownHook(config.config));
184
- }
185
- };
186
- }
187
- function createRemoveOutputDirsTask() {
188
- return {
189
- setup: async (reporter, {
190
- config
191
- }) => {
192
- const outputDirs = new Set();
193
- const projects = (0, _projectUtils.filterProjects)(config.projects, config.cliProjectFilter);
194
- projects.forEach(p => outputDirs.add(p.project.outputDir));
195
- await Promise.all(Array.from(outputDirs).map(outputDir => (0, _utils.removeFolders)([outputDir]).then(async ([error]) => {
196
- if (!error) return;
197
- if (error.code === 'EBUSY') {
198
- // We failed to remove folder, might be due to the whole folder being mounted inside a container:
199
- // https://github.com/microsoft/playwright/issues/12106
200
- // Do a best-effort to remove all files inside of it instead.
201
- const entries = await readDirAsync(outputDir).catch(e => []);
202
- await Promise.all(entries.map(entry => (0, _utils.removeFolders)([_path.default.join(outputDir, entry)])));
203
- } else {
204
- throw error;
205
- }
206
- })));
207
- }
208
- };
209
- }
210
- function createListFilesTask() {
211
- return {
212
- setup: async (reporter, testRun, errors) => {
213
- testRun.rootSuite = await (0, _loadUtils.createRootSuite)(testRun, errors, false);
214
- testRun.failureTracker.onRootSuite(testRun.rootSuite);
215
- await (0, _loadUtils.collectProjectsAndTestFiles)(testRun, false);
216
- for (const [project, files] of testRun.projectFiles) {
217
- const projectSuite = new _test.Suite(project.project.name, 'project');
218
- projectSuite._fullProject = project;
219
- testRun.rootSuite._addSuite(projectSuite);
220
- const suites = files.map(file => {
221
- const title = _path.default.relative(testRun.config.config.rootDir, file);
222
- const suite = new _test.Suite(title, 'file');
223
- suite.location = {
224
- file,
225
- line: 0,
226
- column: 0
227
- };
228
- projectSuite._addSuite(suite);
229
- return suite;
230
- });
231
- testRun.projectSuites.set(project, suites);
232
- }
233
- }
234
- };
235
- }
236
- function createLoadTask(mode, options) {
237
- return {
238
- setup: async (reporter, testRun, errors, softErrors) => {
239
- await (0, _loadUtils.collectProjectsAndTestFiles)(testRun, !!options.doNotRunDepsOutsideProjectFilter);
240
- await (0, _loadUtils.loadFileSuites)(testRun, mode, options.failOnLoadErrors ? errors : softErrors);
241
- let cliOnlyChangedMatcher = undefined;
242
- if (testRun.config.cliOnlyChanged) {
243
- for (const plugin of testRun.config.plugins) {
244
- var _plugin$instance5, _plugin$instance5$pop;
245
- await ((_plugin$instance5 = plugin.instance) === null || _plugin$instance5 === void 0 || (_plugin$instance5$pop = _plugin$instance5.populateDependencies) === null || _plugin$instance5$pop === void 0 ? void 0 : _plugin$instance5$pop.call(_plugin$instance5));
246
- }
247
- const changedFiles = await (0, _vcs.detectChangedTestFiles)(testRun.config.cliOnlyChanged, testRun.config.configDir);
248
- cliOnlyChangedMatcher = file => changedFiles.has(file);
249
- }
250
- testRun.rootSuite = await (0, _loadUtils.createRootSuite)(testRun, options.failOnLoadErrors ? errors : softErrors, !!options.filterOnly, cliOnlyChangedMatcher);
251
- testRun.failureTracker.onRootSuite(testRun.rootSuite);
252
- // Fail when no tests.
253
- if (options.failOnLoadErrors && !testRun.rootSuite.allTests().length && !testRun.config.cliPassWithNoTests && !testRun.config.config.shard && !testRun.config.cliOnlyChanged) {
254
- if (testRun.config.cliArgs.length) {
255
- throw new Error([`No tests found.`, `Make sure that arguments are regular expressions matching test files.`, `You may need to escape symbols like "$" or "*" and quote the arguments.`].join('\n'));
256
- }
257
- throw new Error(`No tests found`);
258
- }
259
- }
260
- };
261
- }
262
- function createPhasesTask() {
263
- return {
264
- setup: async (reporter, testRun) => {
265
- let maxConcurrentTestGroups = 0;
266
- const processed = new Set();
267
- const projectToSuite = new Map(testRun.rootSuite.suites.map(suite => [suite._fullProject, suite]));
268
- const allProjects = [...projectToSuite.keys()];
269
- const teardownToSetups = (0, _projectUtils.buildTeardownToSetupsMap)(allProjects);
270
- const teardownToSetupsDependents = new Map();
271
- for (const [teardown, setups] of teardownToSetups) {
272
- const closure = (0, _projectUtils.buildDependentProjects)(setups, allProjects);
273
- closure.delete(teardown);
274
- teardownToSetupsDependents.set(teardown, [...closure]);
275
- }
276
- for (let i = 0; i < projectToSuite.size; i++) {
277
- // Find all projects that have all their dependencies processed by previous phases.
278
- const phaseProjects = [];
279
- for (const project of projectToSuite.keys()) {
280
- if (processed.has(project)) continue;
281
- const projectsThatShouldFinishFirst = [...project.deps, ...(teardownToSetupsDependents.get(project) || [])];
282
- if (projectsThatShouldFinishFirst.find(p => !processed.has(p))) continue;
283
- phaseProjects.push(project);
284
- }
285
-
286
- // Create a new phase.
287
- for (const project of phaseProjects) processed.add(project);
288
- if (phaseProjects.length) {
289
- let testGroupsInPhase = 0;
290
- const phase = {
291
- dispatcher: new _dispatcher.Dispatcher(testRun.config, reporter, testRun.failureTracker),
292
- projects: []
293
- };
294
- testRun.phases.push(phase);
295
- for (const project of phaseProjects) {
296
- const projectSuite = projectToSuite.get(project);
297
- const testGroups = (0, _testGroups.createTestGroups)(projectSuite, testRun.config.config.workers);
298
- phase.projects.push({
299
- project,
300
- projectSuite,
301
- testGroups
302
- });
303
- testGroupsInPhase += testGroups.length;
304
- }
305
- (0, _utilsBundle.debug)('pw:test:task')(`created phase #${testRun.phases.length} with ${phase.projects.map(p => p.project.project.name).sort()} projects, ${testGroupsInPhase} testGroups`);
306
- maxConcurrentTestGroups = Math.max(maxConcurrentTestGroups, testGroupsInPhase);
307
- }
308
- }
309
- testRun.config.config.metadata.actualWorkers = Math.min(testRun.config.config.workers, maxConcurrentTestGroups);
310
- }
311
- };
312
- }
313
- function createRunTestsTask() {
314
- return {
315
- setup: async (reporter, {
316
- phases,
317
- failureTracker
318
- }) => {
319
- const successfulProjects = new Set();
320
- const extraEnvByProjectId = new Map();
321
- const teardownToSetups = (0, _projectUtils.buildTeardownToSetupsMap)(phases.map(phase => phase.projects.map(p => p.project)).flat());
322
- for (const {
323
- dispatcher,
324
- projects
325
- } of phases) {
326
- // Each phase contains dispatcher and a set of test groups.
327
- // We don't want to run the test groups belonging to the projects
328
- // that depend on the projects that failed previously.
329
- const phaseTestGroups = [];
330
- for (const {
331
- project,
332
- testGroups
333
- } of projects) {
334
- // Inherit extra environment variables from dependencies.
335
- let extraEnv = {};
336
- for (const dep of project.deps) extraEnv = {
337
- ...extraEnv,
338
- ...extraEnvByProjectId.get(dep.id)
339
- };
340
- for (const setup of teardownToSetups.get(project) || []) extraEnv = {
341
- ...extraEnv,
342
- ...extraEnvByProjectId.get(setup.id)
343
- };
344
- extraEnvByProjectId.set(project.id, extraEnv);
345
- const hasFailedDeps = project.deps.some(p => !successfulProjects.has(p));
346
- if (!hasFailedDeps) phaseTestGroups.push(...testGroups);
347
- }
348
- if (phaseTestGroups.length) {
349
- await dispatcher.run(phaseTestGroups, extraEnvByProjectId);
350
- await dispatcher.stop();
351
- for (const [projectId, envProduced] of dispatcher.producedEnvByProjectId()) {
352
- const extraEnv = extraEnvByProjectId.get(projectId) || {};
353
- extraEnvByProjectId.set(projectId, {
354
- ...extraEnv,
355
- ...envProduced
356
- });
357
- }
358
- }
359
-
360
- // If the worker broke, fail everything, we have no way of knowing which
361
- // projects failed.
362
- if (!failureTracker.hasWorkerErrors()) {
363
- for (const {
364
- project,
365
- projectSuite
366
- } of projects) {
367
- const hasFailedDeps = project.deps.some(p => !successfulProjects.has(p));
368
- if (!hasFailedDeps && !projectSuite.allTests().some(test => !test.ok())) successfulProjects.add(project);
369
- }
370
- }
371
- }
372
- },
373
- teardown: async (reporter, {
374
- phases
375
- }) => {
376
- for (const {
377
- dispatcher
378
- } of phases.reverse()) await dispatcher.stop();
379
- }
380
- };
381
- }
382
- function createStartDevServerTask() {
383
- return {
384
- setup: async (reporter, testRun, errors, softErrors) => {
385
- if (testRun.config.plugins.some(plugin => !!plugin.devServerCleanup)) {
386
- errors.push({
387
- message: `DevServer is already running`
388
- });
389
- return;
390
- }
391
- for (const plugin of testRun.config.plugins) {
392
- var _plugin$instance6, _plugin$instance6$sta;
393
- plugin.devServerCleanup = await ((_plugin$instance6 = plugin.instance) === null || _plugin$instance6 === void 0 || (_plugin$instance6$sta = _plugin$instance6.startDevServer) === null || _plugin$instance6$sta === void 0 ? void 0 : _plugin$instance6$sta.call(_plugin$instance6));
394
- }
395
- if (!testRun.config.plugins.some(plugin => !!plugin.devServerCleanup)) errors.push({
396
- message: `DevServer is not available in the package you are using. Did you mean to use component testing?`
397
- });
398
- },
399
- teardown: async (reporter, testRun) => {
400
- for (const plugin of testRun.config.plugins) {
401
- var _plugin$devServerClea;
402
- await ((_plugin$devServerClea = plugin.devServerCleanup) === null || _plugin$devServerClea === void 0 ? void 0 : _plugin$devServerClea.call(plugin));
403
- plugin.devServerCleanup = undefined;
404
- }
405
- }
406
- };
407
- }
@@ -1,136 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.createTestGroups = createTestGroups;
7
- exports.filterForShard = filterForShard;
8
- /**
9
- * Copyright Microsoft Corporation. All rights reserved.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License.
22
- */
23
-
24
- function createTestGroups(projectSuite, workers) {
25
- // This function groups tests that can be run together.
26
- // Tests cannot be run together when:
27
- // - They belong to different projects - requires different workers.
28
- // - They have a different repeatEachIndex - requires different workers.
29
- // - They have a different set of worker fixtures in the pool - requires different workers.
30
- // - They have a different requireFile - reuses the worker, but runs each requireFile separately.
31
- // - They belong to a parallel suite.
32
-
33
- // Using the map "workerHash -> requireFile -> group" makes us preserve the natural order
34
- // of worker hashes and require files for the simple cases.
35
- const groups = new Map();
36
- const createGroup = test => {
37
- return {
38
- workerHash: test._workerHash,
39
- requireFile: test._requireFile,
40
- repeatEachIndex: test.repeatEachIndex,
41
- projectId: test._projectId,
42
- tests: []
43
- };
44
- };
45
- for (const test of projectSuite.allTests()) {
46
- let withWorkerHash = groups.get(test._workerHash);
47
- if (!withWorkerHash) {
48
- withWorkerHash = new Map();
49
- groups.set(test._workerHash, withWorkerHash);
50
- }
51
- let withRequireFile = withWorkerHash.get(test._requireFile);
52
- if (!withRequireFile) {
53
- withRequireFile = {
54
- general: createGroup(test),
55
- parallel: new Map(),
56
- parallelWithHooks: createGroup(test)
57
- };
58
- withWorkerHash.set(test._requireFile, withRequireFile);
59
- }
60
-
61
- // Note that a parallel suite cannot be inside a serial suite. This is enforced in TestType.
62
- let insideParallel = false;
63
- let outerMostSequentialSuite;
64
- let hasAllHooks = false;
65
- for (let parent = test.parent; parent; parent = parent.parent) {
66
- if (parent._parallelMode === 'serial' || parent._parallelMode === 'default') outerMostSequentialSuite = parent;
67
- insideParallel = insideParallel || parent._parallelMode === 'parallel';
68
- hasAllHooks = hasAllHooks || parent._hooks.some(hook => hook.type === 'beforeAll' || hook.type === 'afterAll');
69
- }
70
- if (insideParallel) {
71
- if (hasAllHooks && !outerMostSequentialSuite) {
72
- withRequireFile.parallelWithHooks.tests.push(test);
73
- } else {
74
- const key = outerMostSequentialSuite || test;
75
- let group = withRequireFile.parallel.get(key);
76
- if (!group) {
77
- group = createGroup(test);
78
- withRequireFile.parallel.set(key, group);
79
- }
80
- group.tests.push(test);
81
- }
82
- } else {
83
- withRequireFile.general.tests.push(test);
84
- }
85
- }
86
- const result = [];
87
- for (const withWorkerHash of groups.values()) {
88
- for (const withRequireFile of withWorkerHash.values()) {
89
- // Tests without parallel mode should run serially as a single group.
90
- if (withRequireFile.general.tests.length) result.push(withRequireFile.general);
91
-
92
- // Parallel test groups without beforeAll/afterAll can be run independently.
93
- result.push(...withRequireFile.parallel.values());
94
-
95
- // Tests with beforeAll/afterAll should try to share workers as much as possible.
96
- const parallelWithHooksGroupSize = Math.ceil(withRequireFile.parallelWithHooks.tests.length / workers);
97
- let lastGroup;
98
- for (const test of withRequireFile.parallelWithHooks.tests) {
99
- if (!lastGroup || lastGroup.tests.length >= parallelWithHooksGroupSize) {
100
- lastGroup = createGroup(test);
101
- result.push(lastGroup);
102
- }
103
- lastGroup.tests.push(test);
104
- }
105
- }
106
- }
107
- return result;
108
- }
109
- function filterForShard(shard, testGroups) {
110
- // Note that sharding works based on test groups.
111
- // This means parallel files will be sharded by single tests,
112
- // while non-parallel files will be sharded by the whole file.
113
- //
114
- // Shards are still balanced by the number of tests, not files,
115
- // even in the case of non-paralleled files.
116
-
117
- let shardableTotal = 0;
118
- for (const group of testGroups) shardableTotal += group.tests.length;
119
-
120
- // Each shard gets some tests.
121
- const shardSize = Math.floor(shardableTotal / shard.total);
122
- // First few shards get one more test each.
123
- const extraOne = shardableTotal - shardSize * shard.total;
124
- const currentShard = shard.current - 1; // Make it zero-based for calculations.
125
- const from = shardSize * currentShard + Math.min(extraOne, currentShard);
126
- const to = from + shardSize + (currentShard < extraOne ? 1 : 0);
127
- let current = 0;
128
- const result = new Set();
129
- for (const group of testGroups) {
130
- // Any test group goes to the shard that contains the first test of this group.
131
- // So, this shard gets any group that starts at [from; to)
132
- if (current >= from && current < to) result.add(group);
133
- current += group.tests.length;
134
- }
135
- return result;
136
- }