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.
- checksums.yaml +4 -4
- data/README.md +3 -5
- data/bin/pokeedex +1 -44
- data/lib/pokeedex/configuration.rb +0 -6
- data/lib/pokeedex/install_playwright.rb +62 -0
- data/lib/pokeedex/pokemon/scrapper/fetchers/base.rb +1 -1
- data/lib/pokeedex/version.rb +1 -1
- data/lib/pokeedex.rb +5 -2
- data/spec/pokeedex/configuration_spec.rb +0 -7
- data/spec/spec_helper.rb +1 -1
- metadata +2 -550
- data/node_modules/.bin/playwright +0 -1
- data/node_modules/.bin/playwright-core +0 -1
- data/node_modules/.yarn-integrity +0 -22
- data/node_modules/@playwright/test/LICENSE +0 -202
- data/node_modules/@playwright/test/NOTICE +0 -5
- data/node_modules/@playwright/test/README.md +0 -169
- data/node_modules/@playwright/test/cli.js +0 -19
- data/node_modules/@playwright/test/index.d.ts +0 -18
- data/node_modules/@playwright/test/index.js +0 -17
- data/node_modules/@playwright/test/index.mjs +0 -18
- data/node_modules/@playwright/test/node_modules/.bin/playwright +0 -1
- data/node_modules/@playwright/test/package.json +0 -35
- data/node_modules/@playwright/test/reporter.d.ts +0 -17
- data/node_modules/@playwright/test/reporter.js +0 -17
- data/node_modules/@playwright/test/reporter.mjs +0 -17
- data/node_modules/@types/node/LICENSE +0 -21
- data/node_modules/@types/node/README.md +0 -15
- data/node_modules/@types/node/assert/strict.d.ts +0 -8
- data/node_modules/@types/node/assert.d.ts +0 -1040
- data/node_modules/@types/node/async_hooks.d.ts +0 -541
- data/node_modules/@types/node/buffer.d.ts +0 -2300
- data/node_modules/@types/node/child_process.d.ts +0 -1544
- data/node_modules/@types/node/cluster.d.ts +0 -578
- data/node_modules/@types/node/console.d.ts +0 -452
- data/node_modules/@types/node/constants.d.ts +0 -19
- data/node_modules/@types/node/crypto.d.ts +0 -4451
- data/node_modules/@types/node/dgram.d.ts +0 -596
- data/node_modules/@types/node/diagnostics_channel.d.ts +0 -554
- data/node_modules/@types/node/dns/promises.d.ts +0 -476
- data/node_modules/@types/node/dns.d.ts +0 -865
- data/node_modules/@types/node/dom-events.d.ts +0 -124
- data/node_modules/@types/node/domain.d.ts +0 -170
- data/node_modules/@types/node/events.d.ts +0 -931
- data/node_modules/@types/node/fs/promises.d.ts +0 -1264
- data/node_modules/@types/node/fs.d.ts +0 -4390
- data/node_modules/@types/node/globals.d.ts +0 -611
- data/node_modules/@types/node/globals.global.d.ts +0 -1
- data/node_modules/@types/node/http.d.ts +0 -1921
- data/node_modules/@types/node/http2.d.ts +0 -2555
- data/node_modules/@types/node/https.d.ts +0 -544
- data/node_modules/@types/node/index.d.ts +0 -90
- data/node_modules/@types/node/inspector.d.ts +0 -3966
- data/node_modules/@types/node/module.d.ts +0 -301
- data/node_modules/@types/node/net.d.ts +0 -995
- data/node_modules/@types/node/os.d.ts +0 -495
- data/node_modules/@types/node/package.json +0 -217
- data/node_modules/@types/node/path.d.ts +0 -200
- data/node_modules/@types/node/perf_hooks.d.ts +0 -941
- data/node_modules/@types/node/process.d.ts +0 -1912
- data/node_modules/@types/node/punycode.d.ts +0 -117
- data/node_modules/@types/node/querystring.d.ts +0 -153
- data/node_modules/@types/node/readline/promises.d.ts +0 -150
- data/node_modules/@types/node/readline.d.ts +0 -540
- data/node_modules/@types/node/repl.d.ts +0 -430
- data/node_modules/@types/node/sea.d.ts +0 -153
- data/node_modules/@types/node/sqlite.d.ts +0 -213
- data/node_modules/@types/node/stream/consumers.d.ts +0 -12
- data/node_modules/@types/node/stream/promises.d.ts +0 -83
- data/node_modules/@types/node/stream/web.d.ts +0 -606
- data/node_modules/@types/node/stream.d.ts +0 -1726
- data/node_modules/@types/node/string_decoder.d.ts +0 -67
- data/node_modules/@types/node/test.d.ts +0 -2098
- data/node_modules/@types/node/timers/promises.d.ts +0 -97
- data/node_modules/@types/node/timers.d.ts +0 -240
- data/node_modules/@types/node/tls.d.ts +0 -1220
- data/node_modules/@types/node/trace_events.d.ts +0 -197
- data/node_modules/@types/node/tty.d.ts +0 -208
- data/node_modules/@types/node/url.d.ts +0 -969
- data/node_modules/@types/node/util.d.ts +0 -2301
- data/node_modules/@types/node/v8.d.ts +0 -808
- data/node_modules/@types/node/vm.d.ts +0 -922
- data/node_modules/@types/node/wasi.d.ts +0 -181
- data/node_modules/@types/node/worker_threads.d.ts +0 -712
- data/node_modules/@types/node/zlib.d.ts +0 -539
- data/node_modules/fsevents/LICENSE +0 -22
- data/node_modules/fsevents/README.md +0 -83
- data/node_modules/fsevents/fsevents.d.ts +0 -46
- data/node_modules/fsevents/fsevents.js +0 -82
- data/node_modules/fsevents/fsevents.node +0 -0
- data/node_modules/fsevents/package.json +0 -62
- data/node_modules/playwright/.eslintrc.js +0 -6
- data/node_modules/playwright/LICENSE +0 -202
- data/node_modules/playwright/NOTICE +0 -5
- data/node_modules/playwright/README.md +0 -169
- data/node_modules/playwright/ThirdPartyNotices.txt +0 -4356
- data/node_modules/playwright/cli.js +0 -19
- data/node_modules/playwright/index.d.ts +0 -17
- data/node_modules/playwright/index.js +0 -17
- data/node_modules/playwright/index.mjs +0 -18
- data/node_modules/playwright/jsx-runtime.js +0 -41
- data/node_modules/playwright/jsx-runtime.mjs +0 -21
- data/node_modules/playwright/lib/common/config.js +0 -256
- data/node_modules/playwright/lib/common/configLoader.js +0 -321
- data/node_modules/playwright/lib/common/esmLoaderHost.js +0 -93
- data/node_modules/playwright/lib/common/expectBundle.js +0 -27
- data/node_modules/playwright/lib/common/expectBundleImpl.js +0 -389
- data/node_modules/playwright/lib/common/fixtures.js +0 -323
- data/node_modules/playwright/lib/common/globals.js +0 -48
- data/node_modules/playwright/lib/common/ipc.js +0 -48
- data/node_modules/playwright/lib/common/poolBuilder.js +0 -79
- data/node_modules/playwright/lib/common/process.js +0 -140
- data/node_modules/playwright/lib/common/suiteUtils.js +0 -133
- data/node_modules/playwright/lib/common/test.js +0 -311
- data/node_modules/playwright/lib/common/testLoader.js +0 -102
- data/node_modules/playwright/lib/common/testType.js +0 -284
- data/node_modules/playwright/lib/fsWatcher.js +0 -69
- data/node_modules/playwright/lib/index.js +0 -888
- data/node_modules/playwright/lib/internalsForTest.js +0 -28
- data/node_modules/playwright/lib/isomorphic/events.js +0 -72
- data/node_modules/playwright/lib/isomorphic/folders.js +0 -25
- data/node_modules/playwright/lib/isomorphic/stringInternPool.js +0 -58
- data/node_modules/playwright/lib/isomorphic/teleReceiver.js +0 -504
- data/node_modules/playwright/lib/isomorphic/teleSuiteUpdater.js +0 -149
- data/node_modules/playwright/lib/isomorphic/testServerConnection.js +0 -210
- data/node_modules/playwright/lib/isomorphic/testServerInterface.js +0 -5
- data/node_modules/playwright/lib/isomorphic/testTree.js +0 -272
- data/node_modules/playwright/lib/loader/loaderMain.js +0 -58
- data/node_modules/playwright/lib/matchers/expect.js +0 -297
- data/node_modules/playwright/lib/matchers/matcherHint.js +0 -50
- data/node_modules/playwright/lib/matchers/matchers.js +0 -449
- data/node_modules/playwright/lib/matchers/toBeTruthy.js +0 -55
- data/node_modules/playwright/lib/matchers/toEqual.js +0 -57
- data/node_modules/playwright/lib/matchers/toMatchSnapshot.js +0 -383
- data/node_modules/playwright/lib/matchers/toMatchText.js +0 -76
- data/node_modules/playwright/lib/plugins/gitCommitInfoPlugin.js +0 -78
- data/node_modules/playwright/lib/plugins/index.js +0 -19
- data/node_modules/playwright/lib/plugins/webServerPlugin.js +0 -187
- data/node_modules/playwright/lib/program.js +0 -346
- data/node_modules/playwright/lib/reporters/base.js +0 -553
- data/node_modules/playwright/lib/reporters/blob.js +0 -133
- data/node_modules/playwright/lib/reporters/dot.js +0 -82
- data/node_modules/playwright/lib/reporters/empty.js +0 -42
- data/node_modules/playwright/lib/reporters/github.js +0 -115
- data/node_modules/playwright/lib/reporters/html.js +0 -623
- data/node_modules/playwright/lib/reporters/internalReporter.js +0 -123
- data/node_modules/playwright/lib/reporters/json.js +0 -243
- data/node_modules/playwright/lib/reporters/junit.js +0 -233
- data/node_modules/playwright/lib/reporters/line.js +0 -108
- data/node_modules/playwright/lib/reporters/list.js +0 -222
- data/node_modules/playwright/lib/reporters/markdown.js +0 -76
- data/node_modules/playwright/lib/reporters/merge.js +0 -477
- data/node_modules/playwright/lib/reporters/multiplexer.js +0 -90
- data/node_modules/playwright/lib/reporters/reporterV2.js +0 -118
- data/node_modules/playwright/lib/reporters/teleEmitter.js +0 -268
- data/node_modules/playwright/lib/reporters/versions/blobV1.js +0 -5
- data/node_modules/playwright/lib/runner/dispatcher.js +0 -532
- data/node_modules/playwright/lib/runner/failureTracker.js +0 -60
- data/node_modules/playwright/lib/runner/loadUtils.js +0 -308
- data/node_modules/playwright/lib/runner/loaderHost.js +0 -85
- data/node_modules/playwright/lib/runner/processHost.js +0 -175
- data/node_modules/playwright/lib/runner/projectUtils.js +0 -203
- data/node_modules/playwright/lib/runner/reporters.js +0 -151
- data/node_modules/playwright/lib/runner/runner.js +0 -179
- data/node_modules/playwright/lib/runner/sigIntWatcher.js +0 -100
- data/node_modules/playwright/lib/runner/taskRunner.js +0 -147
- data/node_modules/playwright/lib/runner/tasks.js +0 -407
- data/node_modules/playwright/lib/runner/testGroups.js +0 -136
- data/node_modules/playwright/lib/runner/testServer.js +0 -605
- data/node_modules/playwright/lib/runner/uiModeReporter.js +0 -31
- data/node_modules/playwright/lib/runner/vcs.js +0 -55
- data/node_modules/playwright/lib/runner/watchMode.js +0 -398
- data/node_modules/playwright/lib/runner/workerHost.js +0 -85
- data/node_modules/playwright/lib/third_party/tsconfig-loader.js +0 -134
- data/node_modules/playwright/lib/transform/babelBundle.js +0 -28
- data/node_modules/playwright/lib/transform/babelBundleImpl.js +0 -2032
- data/node_modules/playwright/lib/transform/compilationCache.js +0 -254
- data/node_modules/playwright/lib/transform/esmLoader.js +0 -117
- data/node_modules/playwright/lib/transform/esmUtils.js +0 -32
- data/node_modules/playwright/lib/transform/portTransport.js +0 -81
- data/node_modules/playwright/lib/transform/transform.js +0 -267
- data/node_modules/playwright/lib/util.js +0 -356
- data/node_modules/playwright/lib/utilsBundle.js +0 -28
- data/node_modules/playwright/lib/utilsBundleImpl.js +0 -102
- data/node_modules/playwright/lib/worker/fixtureRunner.js +0 -279
- data/node_modules/playwright/lib/worker/testInfo.js +0 -397
- data/node_modules/playwright/lib/worker/testTracing.js +0 -314
- data/node_modules/playwright/lib/worker/timeoutManager.js +0 -153
- data/node_modules/playwright/lib/worker/workerMain.js +0 -637
- data/node_modules/playwright/node_modules/.bin/playwright-core +0 -1
- data/node_modules/playwright/package.json +0 -66
- data/node_modules/playwright/test.d.ts +0 -18
- data/node_modules/playwright/test.js +0 -24
- data/node_modules/playwright/test.mjs +0 -33
- data/node_modules/playwright/types/test.d.ts +0 -8444
- data/node_modules/playwright/types/testReporter.d.ts +0 -749
- data/node_modules/playwright-core/LICENSE +0 -202
- data/node_modules/playwright-core/NOTICE +0 -5
- data/node_modules/playwright-core/README.md +0 -3
- data/node_modules/playwright-core/ThirdPartyNotices.txt +0 -1548
- data/node_modules/playwright-core/bin/PrintDeps.exe +0 -0
- data/node_modules/playwright-core/bin/README.md +0 -2
- data/node_modules/playwright-core/bin/install_media_pack.ps1 +0 -5
- data/node_modules/playwright-core/bin/reinstall_chrome_beta_linux.sh +0 -40
- data/node_modules/playwright-core/bin/reinstall_chrome_beta_mac.sh +0 -13
- data/node_modules/playwright-core/bin/reinstall_chrome_beta_win.ps1 +0 -24
- data/node_modules/playwright-core/bin/reinstall_chrome_stable_linux.sh +0 -40
- data/node_modules/playwright-core/bin/reinstall_chrome_stable_mac.sh +0 -12
- data/node_modules/playwright-core/bin/reinstall_chrome_stable_win.ps1 +0 -24
- data/node_modules/playwright-core/bin/reinstall_msedge_beta_linux.sh +0 -40
- data/node_modules/playwright-core/bin/reinstall_msedge_beta_mac.sh +0 -11
- data/node_modules/playwright-core/bin/reinstall_msedge_beta_win.ps1 +0 -23
- data/node_modules/playwright-core/bin/reinstall_msedge_dev_linux.sh +0 -40
- data/node_modules/playwright-core/bin/reinstall_msedge_dev_mac.sh +0 -11
- data/node_modules/playwright-core/bin/reinstall_msedge_dev_win.ps1 +0 -23
- data/node_modules/playwright-core/bin/reinstall_msedge_stable_linux.sh +0 -40
- data/node_modules/playwright-core/bin/reinstall_msedge_stable_mac.sh +0 -11
- data/node_modules/playwright-core/bin/reinstall_msedge_stable_win.ps1 +0 -24
- data/node_modules/playwright-core/browsers.json +0 -53
- data/node_modules/playwright-core/cli.js +0 -18
- data/node_modules/playwright-core/index.d.ts +0 -17
- data/node_modules/playwright-core/index.js +0 -33
- data/node_modules/playwright-core/index.mjs +0 -28
- data/node_modules/playwright-core/lib/androidServerImpl.js +0 -69
- data/node_modules/playwright-core/lib/browserServerImpl.js +0 -92
- data/node_modules/playwright-core/lib/cli/driver.js +0 -95
- data/node_modules/playwright-core/lib/cli/program.js +0 -577
- data/node_modules/playwright-core/lib/cli/programWithTestStub.js +0 -67
- data/node_modules/playwright-core/lib/client/accessibility.js +0 -50
- data/node_modules/playwright-core/lib/client/android.js +0 -473
- data/node_modules/playwright-core/lib/client/api.js +0 -279
- data/node_modules/playwright-core/lib/client/artifact.js +0 -79
- data/node_modules/playwright-core/lib/client/browser.js +0 -145
- data/node_modules/playwright-core/lib/client/browserContext.js +0 -541
- data/node_modules/playwright-core/lib/client/browserType.js +0 -241
- data/node_modules/playwright-core/lib/client/cdpSession.js +0 -53
- data/node_modules/playwright-core/lib/client/channelOwner.js +0 -231
- data/node_modules/playwright-core/lib/client/clientHelper.js +0 -57
- data/node_modules/playwright-core/lib/client/clientInstrumentation.js +0 -50
- data/node_modules/playwright-core/lib/client/clock.js +0 -68
- data/node_modules/playwright-core/lib/client/connection.js +0 -330
- data/node_modules/playwright-core/lib/client/consoleMessage.js +0 -55
- data/node_modules/playwright-core/lib/client/coverage.js +0 -41
- data/node_modules/playwright-core/lib/client/dialog.js +0 -57
- data/node_modules/playwright-core/lib/client/download.js +0 -62
- data/node_modules/playwright-core/lib/client/electron.js +0 -135
- data/node_modules/playwright-core/lib/client/elementHandle.js +0 -321
- data/node_modules/playwright-core/lib/client/errors.js +0 -77
- data/node_modules/playwright-core/lib/client/eventEmitter.js +0 -314
- data/node_modules/playwright-core/lib/client/events.js +0 -94
- data/node_modules/playwright-core/lib/client/fetch.js +0 -396
- data/node_modules/playwright-core/lib/client/fileChooser.js +0 -45
- data/node_modules/playwright-core/lib/client/frame.js +0 -504
- data/node_modules/playwright-core/lib/client/harRouter.js +0 -99
- data/node_modules/playwright-core/lib/client/input.js +0 -111
- data/node_modules/playwright-core/lib/client/jsHandle.js +0 -129
- data/node_modules/playwright-core/lib/client/jsonPipe.js +0 -35
- data/node_modules/playwright-core/lib/client/localUtils.js +0 -35
- data/node_modules/playwright-core/lib/client/locator.js +0 -441
- data/node_modules/playwright-core/lib/client/network.js +0 -604
- data/node_modules/playwright-core/lib/client/page.js +0 -725
- data/node_modules/playwright-core/lib/client/playwright.js +0 -77
- data/node_modules/playwright-core/lib/client/selectors.js +0 -67
- data/node_modules/playwright-core/lib/client/stream.js +0 -54
- data/node_modules/playwright-core/lib/client/tracing.js +0 -138
- data/node_modules/playwright-core/lib/client/types.js +0 -24
- data/node_modules/playwright-core/lib/client/video.js +0 -51
- data/node_modules/playwright-core/lib/client/waiter.js +0 -158
- data/node_modules/playwright-core/lib/client/webError.js +0 -37
- data/node_modules/playwright-core/lib/client/worker.js +0 -71
- data/node_modules/playwright-core/lib/client/writableStream.js +0 -54
- data/node_modules/playwright-core/lib/common/socksProxy.js +0 -569
- data/node_modules/playwright-core/lib/common/timeoutSettings.js +0 -73
- data/node_modules/playwright-core/lib/common/types.js +0 -5
- data/node_modules/playwright-core/lib/generated/clockSource.js +0 -7
- data/node_modules/playwright-core/lib/generated/consoleApiSource.js +0 -7
- data/node_modules/playwright-core/lib/generated/injectedScriptSource.js +0 -7
- data/node_modules/playwright-core/lib/generated/recorderSource.js +0 -7
- data/node_modules/playwright-core/lib/generated/utilityScriptSource.js +0 -7
- data/node_modules/playwright-core/lib/image_tools/colorUtils.js +0 -98
- data/node_modules/playwright-core/lib/image_tools/compare.js +0 -108
- data/node_modules/playwright-core/lib/image_tools/imageChannel.js +0 -70
- data/node_modules/playwright-core/lib/image_tools/stats.js +0 -102
- data/node_modules/playwright-core/lib/inProcessFactory.js +0 -54
- data/node_modules/playwright-core/lib/inprocess.js +0 -20
- data/node_modules/playwright-core/lib/outofprocess.js +0 -67
- data/node_modules/playwright-core/lib/protocol/debug.js +0 -27
- data/node_modules/playwright-core/lib/protocol/serializers.js +0 -173
- data/node_modules/playwright-core/lib/protocol/transport.js +0 -82
- data/node_modules/playwright-core/lib/protocol/validator.js +0 -2694
- data/node_modules/playwright-core/lib/protocol/validatorPrimitives.js +0 -139
- data/node_modules/playwright-core/lib/remote/playwrightConnection.js +0 -274
- data/node_modules/playwright-core/lib/remote/playwrightServer.js +0 -110
- data/node_modules/playwright-core/lib/server/accessibility.js +0 -62
- data/node_modules/playwright-core/lib/server/android/android.js +0 -441
- data/node_modules/playwright-core/lib/server/android/backendAdb.js +0 -172
- data/node_modules/playwright-core/lib/server/artifact.js +0 -104
- data/node_modules/playwright-core/lib/server/bidi/bidiBrowser.js +0 -296
- data/node_modules/playwright-core/lib/server/bidi/bidiConnection.js +0 -206
- data/node_modules/playwright-core/lib/server/bidi/bidiExecutionContext.js +0 -162
- data/node_modules/playwright-core/lib/server/bidi/bidiFirefox.js +0 -110
- data/node_modules/playwright-core/lib/server/bidi/bidiInput.js +0 -174
- data/node_modules/playwright-core/lib/server/bidi/bidiNetworkManager.js +0 -304
- data/node_modules/playwright-core/lib/server/bidi/bidiPage.js +0 -456
- data/node_modules/playwright-core/lib/server/bidi/third_party/bidiDeserializer.js +0 -93
- data/node_modules/playwright-core/lib/server/bidi/third_party/bidiKeyboard.js +0 -238
- data/node_modules/playwright-core/lib/server/bidi/third_party/bidiProtocol.js +0 -139
- data/node_modules/playwright-core/lib/server/bidi/third_party/bidiSerializer.js +0 -144
- data/node_modules/playwright-core/lib/server/browser.js +0 -137
- data/node_modules/playwright-core/lib/server/browserContext.js +0 -684
- data/node_modules/playwright-core/lib/server/browserType.js +0 -307
- data/node_modules/playwright-core/lib/server/chromium/appIcon.png +0 -0
- data/node_modules/playwright-core/lib/server/chromium/chromium.js +0 -362
- data/node_modules/playwright-core/lib/server/chromium/chromiumSwitches.js +0 -44
- data/node_modules/playwright-core/lib/server/chromium/crAccessibility.js +0 -237
- data/node_modules/playwright-core/lib/server/chromium/crBrowser.js +0 -515
- data/node_modules/playwright-core/lib/server/chromium/crConnection.js +0 -228
- data/node_modules/playwright-core/lib/server/chromium/crCoverage.js +0 -246
- data/node_modules/playwright-core/lib/server/chromium/crDevTools.js +0 -104
- data/node_modules/playwright-core/lib/server/chromium/crDragDrop.js +0 -143
- data/node_modules/playwright-core/lib/server/chromium/crExecutionContext.js +0 -156
- data/node_modules/playwright-core/lib/server/chromium/crInput.js +0 -171
- data/node_modules/playwright-core/lib/server/chromium/crNetworkManager.js +0 -767
- data/node_modules/playwright-core/lib/server/chromium/crPage.js +0 -1128
- data/node_modules/playwright-core/lib/server/chromium/crPdf.js +0 -153
- data/node_modules/playwright-core/lib/server/chromium/crProtocolHelper.js +0 -133
- data/node_modules/playwright-core/lib/server/chromium/crServiceWorker.js +0 -112
- data/node_modules/playwright-core/lib/server/chromium/defaultFontFamilies.js +0 -145
- data/node_modules/playwright-core/lib/server/chromium/videoRecorder.js +0 -155
- data/node_modules/playwright-core/lib/server/clock.js +0 -125
- data/node_modules/playwright-core/lib/server/codegen/csharp.js +0 -299
- data/node_modules/playwright-core/lib/server/codegen/java.js +0 -235
- data/node_modules/playwright-core/lib/server/codegen/javascript.js +0 -223
- data/node_modules/playwright-core/lib/server/codegen/jsonl.js +0 -47
- data/node_modules/playwright-core/lib/server/codegen/language.js +0 -76
- data/node_modules/playwright-core/lib/server/codegen/languages.js +0 -30
- data/node_modules/playwright-core/lib/server/codegen/python.js +0 -265
- data/node_modules/playwright-core/lib/server/codegen/types.js +0 -5
- data/node_modules/playwright-core/lib/server/console.js +0 -57
- data/node_modules/playwright-core/lib/server/cookieStore.js +0 -112
- data/node_modules/playwright-core/lib/server/debugController.js +0 -234
- data/node_modules/playwright-core/lib/server/debugger.js +0 -132
- data/node_modules/playwright-core/lib/server/deviceDescriptors.js +0 -26
- data/node_modules/playwright-core/lib/server/deviceDescriptorsSource.json +0 -1669
- data/node_modules/playwright-core/lib/server/dialog.js +0 -70
- data/node_modules/playwright-core/lib/server/dispatchers/androidDispatcher.js +0 -193
- data/node_modules/playwright-core/lib/server/dispatchers/artifactDispatcher.js +0 -118
- data/node_modules/playwright-core/lib/server/dispatchers/browserContextDispatcher.js +0 -351
- data/node_modules/playwright-core/lib/server/dispatchers/browserDispatcher.js +0 -170
- data/node_modules/playwright-core/lib/server/dispatchers/browserTypeDispatcher.js +0 -55
- data/node_modules/playwright-core/lib/server/dispatchers/cdpSessionDispatcher.js +0 -48
- data/node_modules/playwright-core/lib/server/dispatchers/debugControllerDispatcher.js +0 -103
- data/node_modules/playwright-core/lib/server/dispatchers/dialogDispatcher.js +0 -44
- data/node_modules/playwright-core/lib/server/dispatchers/dispatcher.js +0 -395
- data/node_modules/playwright-core/lib/server/dispatchers/electronDispatcher.js +0 -93
- data/node_modules/playwright-core/lib/server/dispatchers/elementHandlerDispatcher.js +0 -228
- data/node_modules/playwright-core/lib/server/dispatchers/frameDispatcher.js +0 -286
- data/node_modules/playwright-core/lib/server/dispatchers/jsHandleDispatcher.js +0 -102
- data/node_modules/playwright-core/lib/server/dispatchers/jsonPipeDispatcher.js +0 -59
- data/node_modules/playwright-core/lib/server/dispatchers/localUtilsDispatcher.js +0 -413
- data/node_modules/playwright-core/lib/server/dispatchers/networkDispatchers.js +0 -221
- data/node_modules/playwright-core/lib/server/dispatchers/pageDispatcher.js +0 -358
- data/node_modules/playwright-core/lib/server/dispatchers/playwrightDispatcher.js +0 -106
- data/node_modules/playwright-core/lib/server/dispatchers/selectorsDispatcher.js +0 -36
- data/node_modules/playwright-core/lib/server/dispatchers/streamDispatcher.js +0 -62
- data/node_modules/playwright-core/lib/server/dispatchers/tracingDispatcher.js +0 -54
- data/node_modules/playwright-core/lib/server/dispatchers/writableStreamDispatcher.js +0 -58
- data/node_modules/playwright-core/lib/server/dom.js +0 -845
- data/node_modules/playwright-core/lib/server/download.js +0 -53
- data/node_modules/playwright-core/lib/server/electron/electron.js +0 -296
- data/node_modules/playwright-core/lib/server/electron/loader.js +0 -57
- data/node_modules/playwright-core/lib/server/errors.js +0 -68
- data/node_modules/playwright-core/lib/server/fetch.js +0 -660
- data/node_modules/playwright-core/lib/server/fileChooser.js +0 -42
- data/node_modules/playwright-core/lib/server/fileUploadUtils.js +0 -75
- data/node_modules/playwright-core/lib/server/firefox/ffAccessibility.js +0 -216
- data/node_modules/playwright-core/lib/server/firefox/ffBrowser.js +0 -458
- data/node_modules/playwright-core/lib/server/firefox/ffConnection.js +0 -168
- data/node_modules/playwright-core/lib/server/firefox/ffExecutionContext.js +0 -138
- data/node_modules/playwright-core/lib/server/firefox/ffInput.js +0 -150
- data/node_modules/playwright-core/lib/server/firefox/ffNetworkManager.js +0 -233
- data/node_modules/playwright-core/lib/server/firefox/ffPage.js +0 -556
- data/node_modules/playwright-core/lib/server/firefox/firefox.js +0 -110
- data/node_modules/playwright-core/lib/server/formData.js +0 -75
- data/node_modules/playwright-core/lib/server/frameSelectors.js +0 -171
- data/node_modules/playwright-core/lib/server/frames.js +0 -1654
- data/node_modules/playwright-core/lib/server/har/harRecorder.js +0 -139
- data/node_modules/playwright-core/lib/server/har/harTracer.js +0 -531
- data/node_modules/playwright-core/lib/server/helper.js +0 -103
- data/node_modules/playwright-core/lib/server/index.js +0 -114
- data/node_modules/playwright-core/lib/server/input.js +0 -311
- data/node_modules/playwright-core/lib/server/instrumentation.js +0 -70
- data/node_modules/playwright-core/lib/server/isomorphic/utilityScriptSerializers.js +0 -226
- data/node_modules/playwright-core/lib/server/javascript.js +0 -306
- data/node_modules/playwright-core/lib/server/launchApp.js +0 -91
- data/node_modules/playwright-core/lib/server/macEditingCommands.js +0 -139
- data/node_modules/playwright-core/lib/server/network.js +0 -617
- data/node_modules/playwright-core/lib/server/page.js +0 -825
- data/node_modules/playwright-core/lib/server/pipeTransport.js +0 -85
- data/node_modules/playwright-core/lib/server/playwright.js +0 -85
- data/node_modules/playwright-core/lib/server/progress.js +0 -102
- data/node_modules/playwright-core/lib/server/protocolError.js +0 -49
- data/node_modules/playwright-core/lib/server/recorder/contextRecorder.js +0 -316
- data/node_modules/playwright-core/lib/server/recorder/recorderActions.js +0 -5
- data/node_modules/playwright-core/lib/server/recorder/recorderApp.js +0 -190
- data/node_modules/playwright-core/lib/server/recorder/recorderCollection.js +0 -127
- data/node_modules/playwright-core/lib/server/recorder/recorderRunner.js +0 -177
- data/node_modules/playwright-core/lib/server/recorder/recorderUtils.js +0 -71
- data/node_modules/playwright-core/lib/server/recorder/throttledFile.js +0 -46
- data/node_modules/playwright-core/lib/server/recorder.js +0 -324
- data/node_modules/playwright-core/lib/server/registry/browserFetcher.js +0 -168
- data/node_modules/playwright-core/lib/server/registry/dependencies.js +0 -322
- data/node_modules/playwright-core/lib/server/registry/index.js +0 -924
- data/node_modules/playwright-core/lib/server/registry/nativeDeps.js +0 -490
- data/node_modules/playwright-core/lib/server/registry/oopDownloadBrowserMain.js +0 -138
- data/node_modules/playwright-core/lib/server/screenshotter.js +0 -348
- data/node_modules/playwright-core/lib/server/selectors.js +0 -73
- data/node_modules/playwright-core/lib/server/socksClientCertificatesInterceptor.js +0 -328
- data/node_modules/playwright-core/lib/server/socksInterceptor.js +0 -100
- data/node_modules/playwright-core/lib/server/trace/recorder/snapshotter.js +0 -171
- data/node_modules/playwright-core/lib/server/trace/recorder/snapshotterInjected.js +0 -493
- data/node_modules/playwright-core/lib/server/trace/recorder/tracing.js +0 -486
- data/node_modules/playwright-core/lib/server/trace/test/inMemorySnapshotter.js +0 -93
- data/node_modules/playwright-core/lib/server/trace/viewer/traceViewer.js +0 -216
- data/node_modules/playwright-core/lib/server/transport.js +0 -191
- data/node_modules/playwright-core/lib/server/types.js +0 -24
- data/node_modules/playwright-core/lib/server/usKeyboardLayout.js +0 -555
- data/node_modules/playwright-core/lib/server/webkit/webkit.js +0 -87
- data/node_modules/playwright-core/lib/server/webkit/wkAccessibility.js +0 -194
- data/node_modules/playwright-core/lib/server/webkit/wkBrowser.js +0 -328
- data/node_modules/playwright-core/lib/server/webkit/wkConnection.js +0 -173
- data/node_modules/playwright-core/lib/server/webkit/wkExecutionContext.js +0 -146
- data/node_modules/playwright-core/lib/server/webkit/wkInput.js +0 -169
- data/node_modules/playwright-core/lib/server/webkit/wkInterceptableRequest.js +0 -162
- data/node_modules/playwright-core/lib/server/webkit/wkPage.js +0 -1216
- data/node_modules/playwright-core/lib/server/webkit/wkProvisionalPage.js +0 -94
- data/node_modules/playwright-core/lib/server/webkit/wkWorkers.js +0 -104
- data/node_modules/playwright-core/lib/third_party/diff_match_patch.js +0 -2222
- data/node_modules/playwright-core/lib/third_party/pixelmatch.js +0 -255
- data/node_modules/playwright-core/lib/utils/ascii.js +0 -31
- data/node_modules/playwright-core/lib/utils/comparators.js +0 -171
- data/node_modules/playwright-core/lib/utils/crypto.js +0 -174
- data/node_modules/playwright-core/lib/utils/debug.js +0 -46
- data/node_modules/playwright-core/lib/utils/debugLogger.js +0 -91
- data/node_modules/playwright-core/lib/utils/env.js +0 -49
- data/node_modules/playwright-core/lib/utils/eventsHelper.js +0 -38
- data/node_modules/playwright-core/lib/utils/expectUtils.js +0 -33
- data/node_modules/playwright-core/lib/utils/fileUtils.js +0 -205
- data/node_modules/playwright-core/lib/utils/happy-eyeballs.js +0 -181
- data/node_modules/playwright-core/lib/utils/headers.js +0 -52
- data/node_modules/playwright-core/lib/utils/hostPlatform.js +0 -133
- data/node_modules/playwright-core/lib/utils/httpServer.js +0 -236
- data/node_modules/playwright-core/lib/utils/index.js +0 -368
- data/node_modules/playwright-core/lib/utils/isomorphic/cssParser.js +0 -250
- data/node_modules/playwright-core/lib/utils/isomorphic/cssTokenizer.js +0 -979
- data/node_modules/playwright-core/lib/utils/isomorphic/locatorGenerators.js +0 -651
- data/node_modules/playwright-core/lib/utils/isomorphic/locatorParser.js +0 -179
- data/node_modules/playwright-core/lib/utils/isomorphic/locatorUtils.js +0 -62
- data/node_modules/playwright-core/lib/utils/isomorphic/mimeType.js +0 -29
- data/node_modules/playwright-core/lib/utils/isomorphic/selectorParser.js +0 -397
- data/node_modules/playwright-core/lib/utils/isomorphic/stringUtils.js +0 -139
- data/node_modules/playwright-core/lib/utils/isomorphic/traceUtils.js +0 -39
- data/node_modules/playwright-core/lib/utils/isomorphic/urlMatch.js +0 -120
- data/node_modules/playwright-core/lib/utils/linuxUtils.js +0 -78
- data/node_modules/playwright-core/lib/utils/manualPromise.js +0 -109
- data/node_modules/playwright-core/lib/utils/multimap.js +0 -75
- data/node_modules/playwright-core/lib/utils/network.js +0 -160
- data/node_modules/playwright-core/lib/utils/processLauncher.js +0 -248
- data/node_modules/playwright-core/lib/utils/profiler.js +0 -53
- data/node_modules/playwright-core/lib/utils/rtti.js +0 -44
- data/node_modules/playwright-core/lib/utils/semaphore.js +0 -51
- data/node_modules/playwright-core/lib/utils/spawnAsync.js +0 -45
- data/node_modules/playwright-core/lib/utils/stackTrace.js +0 -121
- data/node_modules/playwright-core/lib/utils/task.js +0 -58
- data/node_modules/playwright-core/lib/utils/time.js +0 -37
- data/node_modules/playwright-core/lib/utils/timeoutRunner.js +0 -66
- data/node_modules/playwright-core/lib/utils/traceUtils.js +0 -44
- data/node_modules/playwright-core/lib/utils/userAgent.js +0 -105
- data/node_modules/playwright-core/lib/utils/wsServer.js +0 -127
- data/node_modules/playwright-core/lib/utils/zipFile.js +0 -75
- data/node_modules/playwright-core/lib/utils/zones.js +0 -62
- data/node_modules/playwright-core/lib/utilsBundle.js +0 -82
- data/node_modules/playwright-core/lib/utilsBundleImpl/index.js +0 -53
- data/node_modules/playwright-core/lib/utilsBundleImpl/xdg-open +0 -1066
- data/node_modules/playwright-core/lib/vite/htmlReport/index.html +0 -66
- data/node_modules/playwright-core/lib/vite/recorder/assets/codeMirrorModule-aW6Vz3gf.js +0 -24
- data/node_modules/playwright-core/lib/vite/recorder/assets/codeMirrorModule-ez37Vkbh.css +0 -1
- data/node_modules/playwright-core/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
- data/node_modules/playwright-core/lib/vite/recorder/assets/index-B-MT5gKo.css +0 -1
- data/node_modules/playwright-core/lib/vite/recorder/assets/index-DCpXOVIh.js +0 -47
- data/node_modules/playwright-core/lib/vite/recorder/index.html +0 -29
- data/node_modules/playwright-core/lib/vite/recorder/playwright-logo.svg +0 -9
- data/node_modules/playwright-core/lib/vite/traceViewer/assets/codeMirrorModule-eFKCUIu2.js +0 -24
- data/node_modules/playwright-core/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +0 -1
- data/node_modules/playwright-core/lib/vite/traceViewer/assets/workbench-D0cirtfA.js +0 -72
- data/node_modules/playwright-core/lib/vite/traceViewer/assets/xtermModule-BeNbaIVa.js +0 -9
- data/node_modules/playwright-core/lib/vite/traceViewer/codeMirrorModule.ez37Vkbh.css +0 -1
- data/node_modules/playwright-core/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
- data/node_modules/playwright-core/lib/vite/traceViewer/embedded.BkuvsLJp.js +0 -2
- data/node_modules/playwright-core/lib/vite/traceViewer/embedded.html +0 -16
- data/node_modules/playwright-core/lib/vite/traceViewer/embedded.w7WN2u1R.css +0 -1
- data/node_modules/playwright-core/lib/vite/traceViewer/index.C968kAiC.js +0 -2
- data/node_modules/playwright-core/lib/vite/traceViewer/index.CrbWWHbf.css +0 -1
- data/node_modules/playwright-core/lib/vite/traceViewer/index.html +0 -27
- data/node_modules/playwright-core/lib/vite/traceViewer/playwright-logo.svg +0 -9
- data/node_modules/playwright-core/lib/vite/traceViewer/snapshot.html +0 -21
- data/node_modules/playwright-core/lib/vite/traceViewer/sw.bundle.js +0 -3
- data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.BkFnr4V0.js +0 -10
- data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.D3cNFP6u.css +0 -1
- data/node_modules/playwright-core/lib/vite/traceViewer/uiMode.html +0 -18
- data/node_modules/playwright-core/lib/vite/traceViewer/workbench.DjbIuxix.css +0 -1
- data/node_modules/playwright-core/lib/vite/traceViewer/xtermModule.DSXBckUd.css +0 -32
- data/node_modules/playwright-core/lib/zipBundle.js +0 -25
- data/node_modules/playwright-core/lib/zipBundleImpl.js +0 -5
- data/node_modules/playwright-core/package.json +0 -44
- data/node_modules/playwright-core/types/protocol.d.ts +0 -21500
- data/node_modules/playwright-core/types/structs.d.ts +0 -45
- data/node_modules/playwright-core/types/types.d.ts +0 -21431
- data/node_modules/undici-types/LICENSE +0 -21
- data/node_modules/undici-types/README.md +0 -6
- data/node_modules/undici-types/agent.d.ts +0 -31
- data/node_modules/undici-types/api.d.ts +0 -43
- data/node_modules/undici-types/balanced-pool.d.ts +0 -29
- data/node_modules/undici-types/cache.d.ts +0 -36
- data/node_modules/undici-types/client.d.ts +0 -108
- data/node_modules/undici-types/connector.d.ts +0 -34
- data/node_modules/undici-types/content-type.d.ts +0 -21
- data/node_modules/undici-types/cookies.d.ts +0 -28
- data/node_modules/undici-types/diagnostics-channel.d.ts +0 -66
- data/node_modules/undici-types/dispatcher.d.ts +0 -255
- data/node_modules/undici-types/env-http-proxy-agent.d.ts +0 -21
- data/node_modules/undici-types/errors.d.ts +0 -149
- data/node_modules/undici-types/eventsource.d.ts +0 -63
- data/node_modules/undici-types/fetch.d.ts +0 -209
- data/node_modules/undici-types/file.d.ts +0 -39
- data/node_modules/undici-types/filereader.d.ts +0 -54
- data/node_modules/undici-types/formdata.d.ts +0 -108
- data/node_modules/undici-types/global-dispatcher.d.ts +0 -9
- data/node_modules/undici-types/global-origin.d.ts +0 -7
- data/node_modules/undici-types/handlers.d.ts +0 -15
- data/node_modules/undici-types/header.d.ts +0 -4
- data/node_modules/undici-types/index.d.ts +0 -71
- data/node_modules/undici-types/interceptors.d.ts +0 -15
- data/node_modules/undici-types/mock-agent.d.ts +0 -50
- data/node_modules/undici-types/mock-client.d.ts +0 -25
- data/node_modules/undici-types/mock-errors.d.ts +0 -12
- data/node_modules/undici-types/mock-interceptor.d.ts +0 -93
- data/node_modules/undici-types/mock-pool.d.ts +0 -25
- data/node_modules/undici-types/package.json +0 -55
- data/node_modules/undici-types/patch.d.ts +0 -71
- data/node_modules/undici-types/pool-stats.d.ts +0 -19
- data/node_modules/undici-types/pool.d.ts +0 -39
- data/node_modules/undici-types/proxy-agent.d.ts +0 -28
- data/node_modules/undici-types/readable.d.ts +0 -60
- data/node_modules/undici-types/retry-agent.d.ts +0 -8
- data/node_modules/undici-types/retry-handler.d.ts +0 -116
- data/node_modules/undici-types/util.d.ts +0 -18
- data/node_modules/undici-types/webidl.d.ts +0 -222
- data/node_modules/undici-types/websocket.d.ts +0 -152
- 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
|
-
}
|