pokeedex 0.1.0

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 (591) hide show
  1. checksums.yaml +7 -0
  2. data/.github/workflows/main.yml +30 -0
  3. data/.gitignore +13 -0
  4. data/.standard.yml +9 -0
  5. data/CHANGELOG.md +5 -0
  6. data/CODE_OF_CONDUCT.md +132 -0
  7. data/Gemfile +14 -0
  8. data/Gemfile.lock +125 -0
  9. data/LICENSE.txt +21 -0
  10. data/README.md +154 -0
  11. data/Rakefile +20 -0
  12. data/bin/pokeedex +85 -0
  13. data/lib/pokeedex/configuration.rb +47 -0
  14. data/lib/pokeedex/database.rb +42 -0
  15. data/lib/pokeedex/db/migrations/001_create_pokemons.rb +26 -0
  16. data/lib/pokeedex/exceptions.rb +15 -0
  17. data/lib/pokeedex/pokemon/base.rb +16 -0
  18. data/lib/pokeedex/pokemon/decorators/base.rb +112 -0
  19. data/lib/pokeedex/pokemon/model/base.rb +43 -0
  20. data/lib/pokeedex/pokemon/scrapper/base.rb +34 -0
  21. data/lib/pokeedex/pokemon/scrapper/fetchers/base.rb +123 -0
  22. data/lib/pokeedex/pokemon/scrapper/parsers/base.rb +205 -0
  23. data/lib/pokeedex/pokemon/scrapper/pokedex.rb +50 -0
  24. data/lib/pokeedex/pokemon/searcher/base.rb +59 -0
  25. data/lib/pokeedex/version.rb +5 -0
  26. data/lib/pokeedex.rb +55 -0
  27. data/node_modules/.bin/playwright +1 -0
  28. data/node_modules/.bin/playwright-core +1 -0
  29. data/node_modules/.yarn-integrity +22 -0
  30. data/node_modules/@playwright/test/LICENSE +202 -0
  31. data/node_modules/@playwright/test/NOTICE +5 -0
  32. data/node_modules/@playwright/test/README.md +169 -0
  33. data/node_modules/@playwright/test/cli.js +19 -0
  34. data/node_modules/@playwright/test/index.d.ts +18 -0
  35. data/node_modules/@playwright/test/index.js +17 -0
  36. data/node_modules/@playwright/test/index.mjs +18 -0
  37. data/node_modules/@playwright/test/node_modules/.bin/playwright +1 -0
  38. data/node_modules/@playwright/test/package.json +35 -0
  39. data/node_modules/@playwright/test/reporter.d.ts +17 -0
  40. data/node_modules/@playwright/test/reporter.js +17 -0
  41. data/node_modules/@playwright/test/reporter.mjs +17 -0
  42. data/node_modules/@types/node/LICENSE +21 -0
  43. data/node_modules/@types/node/README.md +15 -0
  44. data/node_modules/@types/node/assert/strict.d.ts +8 -0
  45. data/node_modules/@types/node/assert.d.ts +1040 -0
  46. data/node_modules/@types/node/async_hooks.d.ts +541 -0
  47. data/node_modules/@types/node/buffer.d.ts +2300 -0
  48. data/node_modules/@types/node/child_process.d.ts +1544 -0
  49. data/node_modules/@types/node/cluster.d.ts +578 -0
  50. data/node_modules/@types/node/console.d.ts +452 -0
  51. data/node_modules/@types/node/constants.d.ts +19 -0
  52. data/node_modules/@types/node/crypto.d.ts +4451 -0
  53. data/node_modules/@types/node/dgram.d.ts +596 -0
  54. data/node_modules/@types/node/diagnostics_channel.d.ts +554 -0
  55. data/node_modules/@types/node/dns/promises.d.ts +476 -0
  56. data/node_modules/@types/node/dns.d.ts +865 -0
  57. data/node_modules/@types/node/dom-events.d.ts +124 -0
  58. data/node_modules/@types/node/domain.d.ts +170 -0
  59. data/node_modules/@types/node/events.d.ts +931 -0
  60. data/node_modules/@types/node/fs/promises.d.ts +1264 -0
  61. data/node_modules/@types/node/fs.d.ts +4390 -0
  62. data/node_modules/@types/node/globals.d.ts +611 -0
  63. data/node_modules/@types/node/globals.global.d.ts +1 -0
  64. data/node_modules/@types/node/http.d.ts +1921 -0
  65. data/node_modules/@types/node/http2.d.ts +2555 -0
  66. data/node_modules/@types/node/https.d.ts +544 -0
  67. data/node_modules/@types/node/index.d.ts +90 -0
  68. data/node_modules/@types/node/inspector.d.ts +3966 -0
  69. data/node_modules/@types/node/module.d.ts +301 -0
  70. data/node_modules/@types/node/net.d.ts +995 -0
  71. data/node_modules/@types/node/os.d.ts +495 -0
  72. data/node_modules/@types/node/package.json +217 -0
  73. data/node_modules/@types/node/path.d.ts +200 -0
  74. data/node_modules/@types/node/perf_hooks.d.ts +941 -0
  75. data/node_modules/@types/node/process.d.ts +1912 -0
  76. data/node_modules/@types/node/punycode.d.ts +117 -0
  77. data/node_modules/@types/node/querystring.d.ts +153 -0
  78. data/node_modules/@types/node/readline/promises.d.ts +150 -0
  79. data/node_modules/@types/node/readline.d.ts +540 -0
  80. data/node_modules/@types/node/repl.d.ts +430 -0
  81. data/node_modules/@types/node/sea.d.ts +153 -0
  82. data/node_modules/@types/node/sqlite.d.ts +213 -0
  83. data/node_modules/@types/node/stream/consumers.d.ts +12 -0
  84. data/node_modules/@types/node/stream/promises.d.ts +83 -0
  85. data/node_modules/@types/node/stream/web.d.ts +606 -0
  86. data/node_modules/@types/node/stream.d.ts +1726 -0
  87. data/node_modules/@types/node/string_decoder.d.ts +67 -0
  88. data/node_modules/@types/node/test.d.ts +2098 -0
  89. data/node_modules/@types/node/timers/promises.d.ts +97 -0
  90. data/node_modules/@types/node/timers.d.ts +240 -0
  91. data/node_modules/@types/node/tls.d.ts +1220 -0
  92. data/node_modules/@types/node/trace_events.d.ts +197 -0
  93. data/node_modules/@types/node/tty.d.ts +208 -0
  94. data/node_modules/@types/node/url.d.ts +969 -0
  95. data/node_modules/@types/node/util.d.ts +2301 -0
  96. data/node_modules/@types/node/v8.d.ts +808 -0
  97. data/node_modules/@types/node/vm.d.ts +922 -0
  98. data/node_modules/@types/node/wasi.d.ts +181 -0
  99. data/node_modules/@types/node/worker_threads.d.ts +712 -0
  100. data/node_modules/@types/node/zlib.d.ts +539 -0
  101. data/node_modules/fsevents/LICENSE +22 -0
  102. data/node_modules/fsevents/README.md +83 -0
  103. data/node_modules/fsevents/fsevents.d.ts +46 -0
  104. data/node_modules/fsevents/fsevents.js +82 -0
  105. data/node_modules/fsevents/fsevents.node +0 -0
  106. data/node_modules/fsevents/package.json +62 -0
  107. data/node_modules/playwright/.eslintrc.js +6 -0
  108. data/node_modules/playwright/LICENSE +202 -0
  109. data/node_modules/playwright/NOTICE +5 -0
  110. data/node_modules/playwright/README.md +169 -0
  111. data/node_modules/playwright/ThirdPartyNotices.txt +4356 -0
  112. data/node_modules/playwright/cli.js +19 -0
  113. data/node_modules/playwright/index.d.ts +17 -0
  114. data/node_modules/playwright/index.js +17 -0
  115. data/node_modules/playwright/index.mjs +18 -0
  116. data/node_modules/playwright/jsx-runtime.js +41 -0
  117. data/node_modules/playwright/jsx-runtime.mjs +21 -0
  118. data/node_modules/playwright/lib/common/config.js +256 -0
  119. data/node_modules/playwright/lib/common/configLoader.js +321 -0
  120. data/node_modules/playwright/lib/common/esmLoaderHost.js +93 -0
  121. data/node_modules/playwright/lib/common/expectBundle.js +27 -0
  122. data/node_modules/playwright/lib/common/expectBundleImpl.js +389 -0
  123. data/node_modules/playwright/lib/common/fixtures.js +323 -0
  124. data/node_modules/playwright/lib/common/globals.js +48 -0
  125. data/node_modules/playwright/lib/common/ipc.js +48 -0
  126. data/node_modules/playwright/lib/common/poolBuilder.js +79 -0
  127. data/node_modules/playwright/lib/common/process.js +140 -0
  128. data/node_modules/playwright/lib/common/suiteUtils.js +133 -0
  129. data/node_modules/playwright/lib/common/test.js +311 -0
  130. data/node_modules/playwright/lib/common/testLoader.js +102 -0
  131. data/node_modules/playwright/lib/common/testType.js +284 -0
  132. data/node_modules/playwright/lib/fsWatcher.js +69 -0
  133. data/node_modules/playwright/lib/index.js +888 -0
  134. data/node_modules/playwright/lib/internalsForTest.js +28 -0
  135. data/node_modules/playwright/lib/isomorphic/events.js +72 -0
  136. data/node_modules/playwright/lib/isomorphic/folders.js +25 -0
  137. data/node_modules/playwright/lib/isomorphic/stringInternPool.js +58 -0
  138. data/node_modules/playwright/lib/isomorphic/teleReceiver.js +504 -0
  139. data/node_modules/playwright/lib/isomorphic/teleSuiteUpdater.js +149 -0
  140. data/node_modules/playwright/lib/isomorphic/testServerConnection.js +210 -0
  141. data/node_modules/playwright/lib/isomorphic/testServerInterface.js +5 -0
  142. data/node_modules/playwright/lib/isomorphic/testTree.js +272 -0
  143. data/node_modules/playwright/lib/loader/loaderMain.js +58 -0
  144. data/node_modules/playwright/lib/matchers/expect.js +297 -0
  145. data/node_modules/playwright/lib/matchers/matcherHint.js +50 -0
  146. data/node_modules/playwright/lib/matchers/matchers.js +449 -0
  147. data/node_modules/playwright/lib/matchers/toBeTruthy.js +55 -0
  148. data/node_modules/playwright/lib/matchers/toEqual.js +57 -0
  149. data/node_modules/playwright/lib/matchers/toMatchSnapshot.js +383 -0
  150. data/node_modules/playwright/lib/matchers/toMatchText.js +76 -0
  151. data/node_modules/playwright/lib/plugins/gitCommitInfoPlugin.js +78 -0
  152. data/node_modules/playwright/lib/plugins/index.js +19 -0
  153. data/node_modules/playwright/lib/plugins/webServerPlugin.js +187 -0
  154. data/node_modules/playwright/lib/program.js +346 -0
  155. data/node_modules/playwright/lib/reporters/base.js +553 -0
  156. data/node_modules/playwright/lib/reporters/blob.js +133 -0
  157. data/node_modules/playwright/lib/reporters/dot.js +82 -0
  158. data/node_modules/playwright/lib/reporters/empty.js +42 -0
  159. data/node_modules/playwright/lib/reporters/github.js +115 -0
  160. data/node_modules/playwright/lib/reporters/html.js +623 -0
  161. data/node_modules/playwright/lib/reporters/internalReporter.js +123 -0
  162. data/node_modules/playwright/lib/reporters/json.js +243 -0
  163. data/node_modules/playwright/lib/reporters/junit.js +233 -0
  164. data/node_modules/playwright/lib/reporters/line.js +108 -0
  165. data/node_modules/playwright/lib/reporters/list.js +222 -0
  166. data/node_modules/playwright/lib/reporters/markdown.js +76 -0
  167. data/node_modules/playwright/lib/reporters/merge.js +477 -0
  168. data/node_modules/playwright/lib/reporters/multiplexer.js +90 -0
  169. data/node_modules/playwright/lib/reporters/reporterV2.js +118 -0
  170. data/node_modules/playwright/lib/reporters/teleEmitter.js +268 -0
  171. data/node_modules/playwright/lib/reporters/versions/blobV1.js +5 -0
  172. data/node_modules/playwright/lib/runner/dispatcher.js +532 -0
  173. data/node_modules/playwright/lib/runner/failureTracker.js +60 -0
  174. data/node_modules/playwright/lib/runner/loadUtils.js +308 -0
  175. data/node_modules/playwright/lib/runner/loaderHost.js +85 -0
  176. data/node_modules/playwright/lib/runner/processHost.js +175 -0
  177. data/node_modules/playwright/lib/runner/projectUtils.js +203 -0
  178. data/node_modules/playwright/lib/runner/reporters.js +151 -0
  179. data/node_modules/playwright/lib/runner/runner.js +179 -0
  180. data/node_modules/playwright/lib/runner/sigIntWatcher.js +100 -0
  181. data/node_modules/playwright/lib/runner/taskRunner.js +147 -0
  182. data/node_modules/playwright/lib/runner/tasks.js +407 -0
  183. data/node_modules/playwright/lib/runner/testGroups.js +136 -0
  184. data/node_modules/playwright/lib/runner/testServer.js +605 -0
  185. data/node_modules/playwright/lib/runner/uiModeReporter.js +31 -0
  186. data/node_modules/playwright/lib/runner/vcs.js +55 -0
  187. data/node_modules/playwright/lib/runner/watchMode.js +398 -0
  188. data/node_modules/playwright/lib/runner/workerHost.js +85 -0
  189. data/node_modules/playwright/lib/third_party/tsconfig-loader.js +134 -0
  190. data/node_modules/playwright/lib/transform/babelBundle.js +28 -0
  191. data/node_modules/playwright/lib/transform/babelBundleImpl.js +2032 -0
  192. data/node_modules/playwright/lib/transform/compilationCache.js +254 -0
  193. data/node_modules/playwright/lib/transform/esmLoader.js +117 -0
  194. data/node_modules/playwright/lib/transform/esmUtils.js +32 -0
  195. data/node_modules/playwright/lib/transform/portTransport.js +81 -0
  196. data/node_modules/playwright/lib/transform/transform.js +267 -0
  197. data/node_modules/playwright/lib/util.js +356 -0
  198. data/node_modules/playwright/lib/utilsBundle.js +28 -0
  199. data/node_modules/playwright/lib/utilsBundleImpl.js +102 -0
  200. data/node_modules/playwright/lib/worker/fixtureRunner.js +279 -0
  201. data/node_modules/playwright/lib/worker/testInfo.js +397 -0
  202. data/node_modules/playwright/lib/worker/testTracing.js +314 -0
  203. data/node_modules/playwright/lib/worker/timeoutManager.js +153 -0
  204. data/node_modules/playwright/lib/worker/workerMain.js +637 -0
  205. data/node_modules/playwright/node_modules/.bin/playwright-core +1 -0
  206. data/node_modules/playwright/package.json +66 -0
  207. data/node_modules/playwright/test.d.ts +18 -0
  208. data/node_modules/playwright/test.js +24 -0
  209. data/node_modules/playwright/test.mjs +33 -0
  210. data/node_modules/playwright/types/test.d.ts +8444 -0
  211. data/node_modules/playwright/types/testReporter.d.ts +749 -0
  212. data/node_modules/playwright-core/LICENSE +202 -0
  213. data/node_modules/playwright-core/NOTICE +5 -0
  214. data/node_modules/playwright-core/README.md +3 -0
  215. data/node_modules/playwright-core/ThirdPartyNotices.txt +1548 -0
  216. data/node_modules/playwright-core/bin/PrintDeps.exe +0 -0
  217. data/node_modules/playwright-core/bin/README.md +2 -0
  218. data/node_modules/playwright-core/bin/install_media_pack.ps1 +5 -0
  219. data/node_modules/playwright-core/bin/reinstall_chrome_beta_linux.sh +40 -0
  220. data/node_modules/playwright-core/bin/reinstall_chrome_beta_mac.sh +13 -0
  221. data/node_modules/playwright-core/bin/reinstall_chrome_beta_win.ps1 +24 -0
  222. data/node_modules/playwright-core/bin/reinstall_chrome_stable_linux.sh +40 -0
  223. data/node_modules/playwright-core/bin/reinstall_chrome_stable_mac.sh +12 -0
  224. data/node_modules/playwright-core/bin/reinstall_chrome_stable_win.ps1 +24 -0
  225. data/node_modules/playwright-core/bin/reinstall_msedge_beta_linux.sh +40 -0
  226. data/node_modules/playwright-core/bin/reinstall_msedge_beta_mac.sh +11 -0
  227. data/node_modules/playwright-core/bin/reinstall_msedge_beta_win.ps1 +23 -0
  228. data/node_modules/playwright-core/bin/reinstall_msedge_dev_linux.sh +40 -0
  229. data/node_modules/playwright-core/bin/reinstall_msedge_dev_mac.sh +11 -0
  230. data/node_modules/playwright-core/bin/reinstall_msedge_dev_win.ps1 +23 -0
  231. data/node_modules/playwright-core/bin/reinstall_msedge_stable_linux.sh +40 -0
  232. data/node_modules/playwright-core/bin/reinstall_msedge_stable_mac.sh +11 -0
  233. data/node_modules/playwright-core/bin/reinstall_msedge_stable_win.ps1 +24 -0
  234. data/node_modules/playwright-core/browsers.json +53 -0
  235. data/node_modules/playwright-core/cli.js +18 -0
  236. data/node_modules/playwright-core/index.d.ts +17 -0
  237. data/node_modules/playwright-core/index.js +33 -0
  238. data/node_modules/playwright-core/index.mjs +28 -0
  239. data/node_modules/playwright-core/lib/androidServerImpl.js +69 -0
  240. data/node_modules/playwright-core/lib/browserServerImpl.js +92 -0
  241. data/node_modules/playwright-core/lib/cli/driver.js +95 -0
  242. data/node_modules/playwright-core/lib/cli/program.js +577 -0
  243. data/node_modules/playwright-core/lib/cli/programWithTestStub.js +67 -0
  244. data/node_modules/playwright-core/lib/client/accessibility.js +50 -0
  245. data/node_modules/playwright-core/lib/client/android.js +473 -0
  246. data/node_modules/playwright-core/lib/client/api.js +279 -0
  247. data/node_modules/playwright-core/lib/client/artifact.js +79 -0
  248. data/node_modules/playwright-core/lib/client/browser.js +145 -0
  249. data/node_modules/playwright-core/lib/client/browserContext.js +541 -0
  250. data/node_modules/playwright-core/lib/client/browserType.js +241 -0
  251. data/node_modules/playwright-core/lib/client/cdpSession.js +53 -0
  252. data/node_modules/playwright-core/lib/client/channelOwner.js +231 -0
  253. data/node_modules/playwright-core/lib/client/clientHelper.js +57 -0
  254. data/node_modules/playwright-core/lib/client/clientInstrumentation.js +50 -0
  255. data/node_modules/playwright-core/lib/client/clock.js +68 -0
  256. data/node_modules/playwright-core/lib/client/connection.js +330 -0
  257. data/node_modules/playwright-core/lib/client/consoleMessage.js +55 -0
  258. data/node_modules/playwright-core/lib/client/coverage.js +41 -0
  259. data/node_modules/playwright-core/lib/client/dialog.js +57 -0
  260. data/node_modules/playwright-core/lib/client/download.js +62 -0
  261. data/node_modules/playwright-core/lib/client/electron.js +135 -0
  262. data/node_modules/playwright-core/lib/client/elementHandle.js +321 -0
  263. data/node_modules/playwright-core/lib/client/errors.js +77 -0
  264. data/node_modules/playwright-core/lib/client/eventEmitter.js +314 -0
  265. data/node_modules/playwright-core/lib/client/events.js +94 -0
  266. data/node_modules/playwright-core/lib/client/fetch.js +396 -0
  267. data/node_modules/playwright-core/lib/client/fileChooser.js +45 -0
  268. data/node_modules/playwright-core/lib/client/frame.js +504 -0
  269. data/node_modules/playwright-core/lib/client/harRouter.js +99 -0
  270. data/node_modules/playwright-core/lib/client/input.js +111 -0
  271. data/node_modules/playwright-core/lib/client/jsHandle.js +129 -0
  272. data/node_modules/playwright-core/lib/client/jsonPipe.js +35 -0
  273. data/node_modules/playwright-core/lib/client/localUtils.js +35 -0
  274. data/node_modules/playwright-core/lib/client/locator.js +441 -0
  275. data/node_modules/playwright-core/lib/client/network.js +604 -0
  276. data/node_modules/playwright-core/lib/client/page.js +725 -0
  277. data/node_modules/playwright-core/lib/client/playwright.js +77 -0
  278. data/node_modules/playwright-core/lib/client/selectors.js +67 -0
  279. data/node_modules/playwright-core/lib/client/stream.js +54 -0
  280. data/node_modules/playwright-core/lib/client/tracing.js +138 -0
  281. data/node_modules/playwright-core/lib/client/types.js +24 -0
  282. data/node_modules/playwright-core/lib/client/video.js +51 -0
  283. data/node_modules/playwright-core/lib/client/waiter.js +158 -0
  284. data/node_modules/playwright-core/lib/client/webError.js +37 -0
  285. data/node_modules/playwright-core/lib/client/worker.js +71 -0
  286. data/node_modules/playwright-core/lib/client/writableStream.js +54 -0
  287. data/node_modules/playwright-core/lib/common/socksProxy.js +569 -0
  288. data/node_modules/playwright-core/lib/common/timeoutSettings.js +73 -0
  289. data/node_modules/playwright-core/lib/common/types.js +5 -0
  290. data/node_modules/playwright-core/lib/generated/clockSource.js +7 -0
  291. data/node_modules/playwright-core/lib/generated/consoleApiSource.js +7 -0
  292. data/node_modules/playwright-core/lib/generated/injectedScriptSource.js +7 -0
  293. data/node_modules/playwright-core/lib/generated/recorderSource.js +7 -0
  294. data/node_modules/playwright-core/lib/generated/utilityScriptSource.js +7 -0
  295. data/node_modules/playwright-core/lib/image_tools/colorUtils.js +98 -0
  296. data/node_modules/playwright-core/lib/image_tools/compare.js +108 -0
  297. data/node_modules/playwright-core/lib/image_tools/imageChannel.js +70 -0
  298. data/node_modules/playwright-core/lib/image_tools/stats.js +102 -0
  299. data/node_modules/playwright-core/lib/inProcessFactory.js +54 -0
  300. data/node_modules/playwright-core/lib/inprocess.js +20 -0
  301. data/node_modules/playwright-core/lib/outofprocess.js +67 -0
  302. data/node_modules/playwright-core/lib/protocol/debug.js +27 -0
  303. data/node_modules/playwright-core/lib/protocol/serializers.js +173 -0
  304. data/node_modules/playwright-core/lib/protocol/transport.js +82 -0
  305. data/node_modules/playwright-core/lib/protocol/validator.js +2694 -0
  306. data/node_modules/playwright-core/lib/protocol/validatorPrimitives.js +139 -0
  307. data/node_modules/playwright-core/lib/remote/playwrightConnection.js +274 -0
  308. data/node_modules/playwright-core/lib/remote/playwrightServer.js +110 -0
  309. data/node_modules/playwright-core/lib/server/accessibility.js +62 -0
  310. data/node_modules/playwright-core/lib/server/android/android.js +441 -0
  311. data/node_modules/playwright-core/lib/server/android/backendAdb.js +172 -0
  312. data/node_modules/playwright-core/lib/server/artifact.js +104 -0
  313. data/node_modules/playwright-core/lib/server/bidi/bidiBrowser.js +296 -0
  314. data/node_modules/playwright-core/lib/server/bidi/bidiConnection.js +206 -0
  315. data/node_modules/playwright-core/lib/server/bidi/bidiExecutionContext.js +162 -0
  316. data/node_modules/playwright-core/lib/server/bidi/bidiFirefox.js +110 -0
  317. data/node_modules/playwright-core/lib/server/bidi/bidiInput.js +174 -0
  318. data/node_modules/playwright-core/lib/server/bidi/bidiNetworkManager.js +304 -0
  319. data/node_modules/playwright-core/lib/server/bidi/bidiPage.js +456 -0
  320. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiDeserializer.js +93 -0
  321. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiKeyboard.js +238 -0
  322. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiProtocol.js +139 -0
  323. data/node_modules/playwright-core/lib/server/bidi/third_party/bidiSerializer.js +144 -0
  324. data/node_modules/playwright-core/lib/server/browser.js +137 -0
  325. data/node_modules/playwright-core/lib/server/browserContext.js +684 -0
  326. data/node_modules/playwright-core/lib/server/browserType.js +307 -0
  327. data/node_modules/playwright-core/lib/server/chromium/appIcon.png +0 -0
  328. data/node_modules/playwright-core/lib/server/chromium/chromium.js +362 -0
  329. data/node_modules/playwright-core/lib/server/chromium/chromiumSwitches.js +44 -0
  330. data/node_modules/playwright-core/lib/server/chromium/crAccessibility.js +237 -0
  331. data/node_modules/playwright-core/lib/server/chromium/crBrowser.js +515 -0
  332. data/node_modules/playwright-core/lib/server/chromium/crConnection.js +228 -0
  333. data/node_modules/playwright-core/lib/server/chromium/crCoverage.js +246 -0
  334. data/node_modules/playwright-core/lib/server/chromium/crDevTools.js +104 -0
  335. data/node_modules/playwright-core/lib/server/chromium/crDragDrop.js +143 -0
  336. data/node_modules/playwright-core/lib/server/chromium/crExecutionContext.js +156 -0
  337. data/node_modules/playwright-core/lib/server/chromium/crInput.js +171 -0
  338. data/node_modules/playwright-core/lib/server/chromium/crNetworkManager.js +767 -0
  339. data/node_modules/playwright-core/lib/server/chromium/crPage.js +1128 -0
  340. data/node_modules/playwright-core/lib/server/chromium/crPdf.js +153 -0
  341. data/node_modules/playwright-core/lib/server/chromium/crProtocolHelper.js +133 -0
  342. data/node_modules/playwright-core/lib/server/chromium/crServiceWorker.js +112 -0
  343. data/node_modules/playwright-core/lib/server/chromium/defaultFontFamilies.js +145 -0
  344. data/node_modules/playwright-core/lib/server/chromium/videoRecorder.js +155 -0
  345. data/node_modules/playwright-core/lib/server/clock.js +125 -0
  346. data/node_modules/playwright-core/lib/server/codegen/csharp.js +299 -0
  347. data/node_modules/playwright-core/lib/server/codegen/java.js +235 -0
  348. data/node_modules/playwright-core/lib/server/codegen/javascript.js +223 -0
  349. data/node_modules/playwright-core/lib/server/codegen/jsonl.js +47 -0
  350. data/node_modules/playwright-core/lib/server/codegen/language.js +76 -0
  351. data/node_modules/playwright-core/lib/server/codegen/languages.js +30 -0
  352. data/node_modules/playwright-core/lib/server/codegen/python.js +265 -0
  353. data/node_modules/playwright-core/lib/server/codegen/types.js +5 -0
  354. data/node_modules/playwright-core/lib/server/console.js +57 -0
  355. data/node_modules/playwright-core/lib/server/cookieStore.js +112 -0
  356. data/node_modules/playwright-core/lib/server/debugController.js +234 -0
  357. data/node_modules/playwright-core/lib/server/debugger.js +132 -0
  358. data/node_modules/playwright-core/lib/server/deviceDescriptors.js +26 -0
  359. data/node_modules/playwright-core/lib/server/deviceDescriptorsSource.json +1669 -0
  360. data/node_modules/playwright-core/lib/server/dialog.js +70 -0
  361. data/node_modules/playwright-core/lib/server/dispatchers/androidDispatcher.js +193 -0
  362. data/node_modules/playwright-core/lib/server/dispatchers/artifactDispatcher.js +118 -0
  363. data/node_modules/playwright-core/lib/server/dispatchers/browserContextDispatcher.js +351 -0
  364. data/node_modules/playwright-core/lib/server/dispatchers/browserDispatcher.js +170 -0
  365. data/node_modules/playwright-core/lib/server/dispatchers/browserTypeDispatcher.js +55 -0
  366. data/node_modules/playwright-core/lib/server/dispatchers/cdpSessionDispatcher.js +48 -0
  367. data/node_modules/playwright-core/lib/server/dispatchers/debugControllerDispatcher.js +103 -0
  368. data/node_modules/playwright-core/lib/server/dispatchers/dialogDispatcher.js +44 -0
  369. data/node_modules/playwright-core/lib/server/dispatchers/dispatcher.js +395 -0
  370. data/node_modules/playwright-core/lib/server/dispatchers/electronDispatcher.js +93 -0
  371. data/node_modules/playwright-core/lib/server/dispatchers/elementHandlerDispatcher.js +228 -0
  372. data/node_modules/playwright-core/lib/server/dispatchers/frameDispatcher.js +286 -0
  373. data/node_modules/playwright-core/lib/server/dispatchers/jsHandleDispatcher.js +102 -0
  374. data/node_modules/playwright-core/lib/server/dispatchers/jsonPipeDispatcher.js +59 -0
  375. data/node_modules/playwright-core/lib/server/dispatchers/localUtilsDispatcher.js +413 -0
  376. data/node_modules/playwright-core/lib/server/dispatchers/networkDispatchers.js +221 -0
  377. data/node_modules/playwright-core/lib/server/dispatchers/pageDispatcher.js +358 -0
  378. data/node_modules/playwright-core/lib/server/dispatchers/playwrightDispatcher.js +106 -0
  379. data/node_modules/playwright-core/lib/server/dispatchers/selectorsDispatcher.js +36 -0
  380. data/node_modules/playwright-core/lib/server/dispatchers/streamDispatcher.js +62 -0
  381. data/node_modules/playwright-core/lib/server/dispatchers/tracingDispatcher.js +54 -0
  382. data/node_modules/playwright-core/lib/server/dispatchers/writableStreamDispatcher.js +58 -0
  383. data/node_modules/playwright-core/lib/server/dom.js +845 -0
  384. data/node_modules/playwright-core/lib/server/download.js +53 -0
  385. data/node_modules/playwright-core/lib/server/electron/electron.js +296 -0
  386. data/node_modules/playwright-core/lib/server/electron/loader.js +57 -0
  387. data/node_modules/playwright-core/lib/server/errors.js +68 -0
  388. data/node_modules/playwright-core/lib/server/fetch.js +660 -0
  389. data/node_modules/playwright-core/lib/server/fileChooser.js +42 -0
  390. data/node_modules/playwright-core/lib/server/fileUploadUtils.js +75 -0
  391. data/node_modules/playwright-core/lib/server/firefox/ffAccessibility.js +216 -0
  392. data/node_modules/playwright-core/lib/server/firefox/ffBrowser.js +458 -0
  393. data/node_modules/playwright-core/lib/server/firefox/ffConnection.js +168 -0
  394. data/node_modules/playwright-core/lib/server/firefox/ffExecutionContext.js +138 -0
  395. data/node_modules/playwright-core/lib/server/firefox/ffInput.js +150 -0
  396. data/node_modules/playwright-core/lib/server/firefox/ffNetworkManager.js +233 -0
  397. data/node_modules/playwright-core/lib/server/firefox/ffPage.js +556 -0
  398. data/node_modules/playwright-core/lib/server/firefox/firefox.js +110 -0
  399. data/node_modules/playwright-core/lib/server/formData.js +75 -0
  400. data/node_modules/playwright-core/lib/server/frameSelectors.js +171 -0
  401. data/node_modules/playwright-core/lib/server/frames.js +1654 -0
  402. data/node_modules/playwright-core/lib/server/har/harRecorder.js +139 -0
  403. data/node_modules/playwright-core/lib/server/har/harTracer.js +531 -0
  404. data/node_modules/playwright-core/lib/server/helper.js +103 -0
  405. data/node_modules/playwright-core/lib/server/index.js +114 -0
  406. data/node_modules/playwright-core/lib/server/input.js +311 -0
  407. data/node_modules/playwright-core/lib/server/instrumentation.js +70 -0
  408. data/node_modules/playwright-core/lib/server/isomorphic/utilityScriptSerializers.js +226 -0
  409. data/node_modules/playwright-core/lib/server/javascript.js +306 -0
  410. data/node_modules/playwright-core/lib/server/launchApp.js +91 -0
  411. data/node_modules/playwright-core/lib/server/macEditingCommands.js +139 -0
  412. data/node_modules/playwright-core/lib/server/network.js +617 -0
  413. data/node_modules/playwright-core/lib/server/page.js +825 -0
  414. data/node_modules/playwright-core/lib/server/pipeTransport.js +85 -0
  415. data/node_modules/playwright-core/lib/server/playwright.js +85 -0
  416. data/node_modules/playwright-core/lib/server/progress.js +102 -0
  417. data/node_modules/playwright-core/lib/server/protocolError.js +49 -0
  418. data/node_modules/playwright-core/lib/server/recorder/contextRecorder.js +316 -0
  419. data/node_modules/playwright-core/lib/server/recorder/recorderActions.js +5 -0
  420. data/node_modules/playwright-core/lib/server/recorder/recorderApp.js +190 -0
  421. data/node_modules/playwright-core/lib/server/recorder/recorderCollection.js +127 -0
  422. data/node_modules/playwright-core/lib/server/recorder/recorderRunner.js +177 -0
  423. data/node_modules/playwright-core/lib/server/recorder/recorderUtils.js +71 -0
  424. data/node_modules/playwright-core/lib/server/recorder/throttledFile.js +46 -0
  425. data/node_modules/playwright-core/lib/server/recorder.js +324 -0
  426. data/node_modules/playwright-core/lib/server/registry/browserFetcher.js +168 -0
  427. data/node_modules/playwright-core/lib/server/registry/dependencies.js +322 -0
  428. data/node_modules/playwright-core/lib/server/registry/index.js +924 -0
  429. data/node_modules/playwright-core/lib/server/registry/nativeDeps.js +490 -0
  430. data/node_modules/playwright-core/lib/server/registry/oopDownloadBrowserMain.js +138 -0
  431. data/node_modules/playwright-core/lib/server/screenshotter.js +348 -0
  432. data/node_modules/playwright-core/lib/server/selectors.js +73 -0
  433. data/node_modules/playwright-core/lib/server/socksClientCertificatesInterceptor.js +328 -0
  434. data/node_modules/playwright-core/lib/server/socksInterceptor.js +100 -0
  435. data/node_modules/playwright-core/lib/server/trace/recorder/snapshotter.js +171 -0
  436. data/node_modules/playwright-core/lib/server/trace/recorder/snapshotterInjected.js +493 -0
  437. data/node_modules/playwright-core/lib/server/trace/recorder/tracing.js +486 -0
  438. data/node_modules/playwright-core/lib/server/trace/test/inMemorySnapshotter.js +93 -0
  439. data/node_modules/playwright-core/lib/server/trace/viewer/traceViewer.js +216 -0
  440. data/node_modules/playwright-core/lib/server/transport.js +191 -0
  441. data/node_modules/playwright-core/lib/server/types.js +24 -0
  442. data/node_modules/playwright-core/lib/server/usKeyboardLayout.js +555 -0
  443. data/node_modules/playwright-core/lib/server/webkit/webkit.js +87 -0
  444. data/node_modules/playwright-core/lib/server/webkit/wkAccessibility.js +194 -0
  445. data/node_modules/playwright-core/lib/server/webkit/wkBrowser.js +328 -0
  446. data/node_modules/playwright-core/lib/server/webkit/wkConnection.js +173 -0
  447. data/node_modules/playwright-core/lib/server/webkit/wkExecutionContext.js +146 -0
  448. data/node_modules/playwright-core/lib/server/webkit/wkInput.js +169 -0
  449. data/node_modules/playwright-core/lib/server/webkit/wkInterceptableRequest.js +162 -0
  450. data/node_modules/playwright-core/lib/server/webkit/wkPage.js +1216 -0
  451. data/node_modules/playwright-core/lib/server/webkit/wkProvisionalPage.js +94 -0
  452. data/node_modules/playwright-core/lib/server/webkit/wkWorkers.js +104 -0
  453. data/node_modules/playwright-core/lib/third_party/diff_match_patch.js +2222 -0
  454. data/node_modules/playwright-core/lib/third_party/pixelmatch.js +255 -0
  455. data/node_modules/playwright-core/lib/utils/ascii.js +31 -0
  456. data/node_modules/playwright-core/lib/utils/comparators.js +171 -0
  457. data/node_modules/playwright-core/lib/utils/crypto.js +174 -0
  458. data/node_modules/playwright-core/lib/utils/debug.js +46 -0
  459. data/node_modules/playwright-core/lib/utils/debugLogger.js +91 -0
  460. data/node_modules/playwright-core/lib/utils/env.js +49 -0
  461. data/node_modules/playwright-core/lib/utils/eventsHelper.js +38 -0
  462. data/node_modules/playwright-core/lib/utils/expectUtils.js +33 -0
  463. data/node_modules/playwright-core/lib/utils/fileUtils.js +205 -0
  464. data/node_modules/playwright-core/lib/utils/happy-eyeballs.js +181 -0
  465. data/node_modules/playwright-core/lib/utils/headers.js +52 -0
  466. data/node_modules/playwright-core/lib/utils/hostPlatform.js +133 -0
  467. data/node_modules/playwright-core/lib/utils/httpServer.js +236 -0
  468. data/node_modules/playwright-core/lib/utils/index.js +368 -0
  469. data/node_modules/playwright-core/lib/utils/isomorphic/cssParser.js +250 -0
  470. data/node_modules/playwright-core/lib/utils/isomorphic/cssTokenizer.js +979 -0
  471. data/node_modules/playwright-core/lib/utils/isomorphic/locatorGenerators.js +651 -0
  472. data/node_modules/playwright-core/lib/utils/isomorphic/locatorParser.js +179 -0
  473. data/node_modules/playwright-core/lib/utils/isomorphic/locatorUtils.js +62 -0
  474. data/node_modules/playwright-core/lib/utils/isomorphic/mimeType.js +29 -0
  475. data/node_modules/playwright-core/lib/utils/isomorphic/selectorParser.js +397 -0
  476. data/node_modules/playwright-core/lib/utils/isomorphic/stringUtils.js +139 -0
  477. data/node_modules/playwright-core/lib/utils/isomorphic/traceUtils.js +39 -0
  478. data/node_modules/playwright-core/lib/utils/isomorphic/urlMatch.js +120 -0
  479. data/node_modules/playwright-core/lib/utils/linuxUtils.js +78 -0
  480. data/node_modules/playwright-core/lib/utils/manualPromise.js +109 -0
  481. data/node_modules/playwright-core/lib/utils/multimap.js +75 -0
  482. data/node_modules/playwright-core/lib/utils/network.js +160 -0
  483. data/node_modules/playwright-core/lib/utils/processLauncher.js +248 -0
  484. data/node_modules/playwright-core/lib/utils/profiler.js +53 -0
  485. data/node_modules/playwright-core/lib/utils/rtti.js +44 -0
  486. data/node_modules/playwright-core/lib/utils/semaphore.js +51 -0
  487. data/node_modules/playwright-core/lib/utils/spawnAsync.js +45 -0
  488. data/node_modules/playwright-core/lib/utils/stackTrace.js +121 -0
  489. data/node_modules/playwright-core/lib/utils/task.js +58 -0
  490. data/node_modules/playwright-core/lib/utils/time.js +37 -0
  491. data/node_modules/playwright-core/lib/utils/timeoutRunner.js +66 -0
  492. data/node_modules/playwright-core/lib/utils/traceUtils.js +44 -0
  493. data/node_modules/playwright-core/lib/utils/userAgent.js +105 -0
  494. data/node_modules/playwright-core/lib/utils/wsServer.js +127 -0
  495. data/node_modules/playwright-core/lib/utils/zipFile.js +75 -0
  496. data/node_modules/playwright-core/lib/utils/zones.js +62 -0
  497. data/node_modules/playwright-core/lib/utilsBundle.js +82 -0
  498. data/node_modules/playwright-core/lib/utilsBundleImpl/index.js +53 -0
  499. data/node_modules/playwright-core/lib/utilsBundleImpl/xdg-open +1066 -0
  500. data/node_modules/playwright-core/lib/vite/htmlReport/index.html +66 -0
  501. data/node_modules/playwright-core/lib/vite/recorder/assets/codeMirrorModule-aW6Vz3gf.js +24 -0
  502. data/node_modules/playwright-core/lib/vite/recorder/assets/codeMirrorModule-ez37Vkbh.css +1 -0
  503. data/node_modules/playwright-core/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
  504. data/node_modules/playwright-core/lib/vite/recorder/assets/index-B-MT5gKo.css +1 -0
  505. data/node_modules/playwright-core/lib/vite/recorder/assets/index-DCpXOVIh.js +47 -0
  506. data/node_modules/playwright-core/lib/vite/recorder/index.html +29 -0
  507. data/node_modules/playwright-core/lib/vite/recorder/playwright-logo.svg +9 -0
  508. data/node_modules/playwright-core/lib/vite/traceViewer/assets/codeMirrorModule-eFKCUIu2.js +24 -0
  509. data/node_modules/playwright-core/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +1 -0
  510. data/node_modules/playwright-core/lib/vite/traceViewer/assets/workbench-D0cirtfA.js +72 -0
  511. data/node_modules/playwright-core/lib/vite/traceViewer/assets/xtermModule-BeNbaIVa.js +9 -0
  512. data/node_modules/playwright-core/lib/vite/traceViewer/codeMirrorModule.ez37Vkbh.css +1 -0
  513. data/node_modules/playwright-core/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
  514. data/node_modules/playwright-core/lib/vite/traceViewer/embedded.BkuvsLJp.js +2 -0
  515. data/node_modules/playwright-core/lib/vite/traceViewer/embedded.html +16 -0
  516. data/node_modules/playwright-core/lib/vite/traceViewer/embedded.w7WN2u1R.css +1 -0
  517. data/node_modules/playwright-core/lib/vite/traceViewer/index.C968kAiC.js +2 -0
  518. data/node_modules/playwright-core/lib/vite/traceViewer/index.CrbWWHbf.css +1 -0
  519. data/node_modules/playwright-core/lib/vite/traceViewer/index.html +27 -0
  520. data/node_modules/playwright-core/lib/vite/traceViewer/playwright-logo.svg +9 -0
  521. data/node_modules/playwright-core/lib/vite/traceViewer/snapshot.html +21 -0
  522. data/node_modules/playwright-core/lib/vite/traceViewer/sw.bundle.js +3 -0
  523. data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.BkFnr4V0.js +10 -0
  524. data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.D3cNFP6u.css +1 -0
  525. data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.html +18 -0
  526. data/node_modules/playwright-core/lib/vite/traceViewer/workbench.DjbIuxix.css +1 -0
  527. data/node_modules/playwright-core/lib/vite/traceViewer/xtermModule.DSXBckUd.css +32 -0
  528. data/node_modules/playwright-core/lib/zipBundle.js +25 -0
  529. data/node_modules/playwright-core/lib/zipBundleImpl.js +5 -0
  530. data/node_modules/playwright-core/package.json +44 -0
  531. data/node_modules/playwright-core/types/protocol.d.ts +21500 -0
  532. data/node_modules/playwright-core/types/structs.d.ts +45 -0
  533. data/node_modules/playwright-core/types/types.d.ts +21431 -0
  534. data/node_modules/undici-types/LICENSE +21 -0
  535. data/node_modules/undici-types/README.md +6 -0
  536. data/node_modules/undici-types/agent.d.ts +31 -0
  537. data/node_modules/undici-types/api.d.ts +43 -0
  538. data/node_modules/undici-types/balanced-pool.d.ts +29 -0
  539. data/node_modules/undici-types/cache.d.ts +36 -0
  540. data/node_modules/undici-types/client.d.ts +108 -0
  541. data/node_modules/undici-types/connector.d.ts +34 -0
  542. data/node_modules/undici-types/content-type.d.ts +21 -0
  543. data/node_modules/undici-types/cookies.d.ts +28 -0
  544. data/node_modules/undici-types/diagnostics-channel.d.ts +66 -0
  545. data/node_modules/undici-types/dispatcher.d.ts +255 -0
  546. data/node_modules/undici-types/env-http-proxy-agent.d.ts +21 -0
  547. data/node_modules/undici-types/errors.d.ts +149 -0
  548. data/node_modules/undici-types/eventsource.d.ts +63 -0
  549. data/node_modules/undici-types/fetch.d.ts +209 -0
  550. data/node_modules/undici-types/file.d.ts +39 -0
  551. data/node_modules/undici-types/filereader.d.ts +54 -0
  552. data/node_modules/undici-types/formdata.d.ts +108 -0
  553. data/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  554. data/node_modules/undici-types/global-origin.d.ts +7 -0
  555. data/node_modules/undici-types/handlers.d.ts +15 -0
  556. data/node_modules/undici-types/header.d.ts +4 -0
  557. data/node_modules/undici-types/index.d.ts +71 -0
  558. data/node_modules/undici-types/interceptors.d.ts +15 -0
  559. data/node_modules/undici-types/mock-agent.d.ts +50 -0
  560. data/node_modules/undici-types/mock-client.d.ts +25 -0
  561. data/node_modules/undici-types/mock-errors.d.ts +12 -0
  562. data/node_modules/undici-types/mock-interceptor.d.ts +93 -0
  563. data/node_modules/undici-types/mock-pool.d.ts +25 -0
  564. data/node_modules/undici-types/package.json +55 -0
  565. data/node_modules/undici-types/patch.d.ts +71 -0
  566. data/node_modules/undici-types/pool-stats.d.ts +19 -0
  567. data/node_modules/undici-types/pool.d.ts +39 -0
  568. data/node_modules/undici-types/proxy-agent.d.ts +28 -0
  569. data/node_modules/undici-types/readable.d.ts +60 -0
  570. data/node_modules/undici-types/retry-agent.d.ts +8 -0
  571. data/node_modules/undici-types/retry-handler.d.ts +116 -0
  572. data/node_modules/undici-types/util.d.ts +18 -0
  573. data/node_modules/undici-types/webidl.d.ts +222 -0
  574. data/node_modules/undici-types/websocket.d.ts +152 -0
  575. data/pokeedex.gemspec +32 -0
  576. data/spec/fixtures/pokemon_com/responses/GET-200-bulbasaur.html +2262 -0
  577. data/spec/fixtures/pokemon_com/responses/GET-404-not-found.html +808 -0
  578. data/spec/pokeedex/configuration_spec.rb +37 -0
  579. data/spec/pokeedex/database_spec.rb +21 -0
  580. data/spec/pokeedex/exceptions_spec.rb +11 -0
  581. data/spec/pokeedex/pokemon/base_spec.rb +15 -0
  582. data/spec/pokeedex/pokemon/decorators/base_spec.rb +63 -0
  583. data/spec/pokeedex/pokemon/model/base_spec.rb +36 -0
  584. data/spec/pokeedex/pokemon/scrapper/fetchers/base_spec.rb +36 -0
  585. data/spec/pokeedex/pokemon/scrapper/parsers/base_spec.rb +49 -0
  586. data/spec/pokeedex/pokemon/scrapper/pokedex_spec.rb +71 -0
  587. data/spec/pokeedex/pokemon/searcher/base.rb +81 -0
  588. data/spec/pokeedex_spec.rb +7 -0
  589. data/spec/spec_helper.rb +42 -0
  590. data/yarn.lock +41 -0
  591. metadata +731 -0
@@ -0,0 +1,147 @@
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
+ }
@@ -0,0 +1,407 @@
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
+ }
@@ -0,0 +1,136 @@
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
+ }