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,684 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
6
|
-
exports.BrowserContext = void 0;
|
7
|
-
exports.assertBrowserContextIsNotOwned = assertBrowserContextIsNotOwned;
|
8
|
-
exports.createClientCertificatesProxyIfNeeded = createClientCertificatesProxyIfNeeded;
|
9
|
-
exports.normalizeProxySettings = normalizeProxySettings;
|
10
|
-
exports.validateBrowserContextOptions = validateBrowserContextOptions;
|
11
|
-
exports.verifyClientCertificates = verifyClientCertificates;
|
12
|
-
exports.verifyGeolocation = verifyGeolocation;
|
13
|
-
var _timeoutSettings = require("../common/timeoutSettings");
|
14
|
-
var _utils = require("../utils");
|
15
|
-
var _fileUtils = require("../utils/fileUtils");
|
16
|
-
var _helper = require("./helper");
|
17
|
-
var network = _interopRequireWildcard(require("./network"));
|
18
|
-
var _page6 = require("./page");
|
19
|
-
var _path = _interopRequireDefault(require("path"));
|
20
|
-
var _fs = _interopRequireDefault(require("fs"));
|
21
|
-
var _instrumentation = require("./instrumentation");
|
22
|
-
var _debugger = require("./debugger");
|
23
|
-
var _tracing = require("./trace/recorder/tracing");
|
24
|
-
var _harRecorder = require("./har/harRecorder");
|
25
|
-
var _recorder = require("./recorder");
|
26
|
-
var consoleApiSource = _interopRequireWildcard(require("../generated/consoleApiSource"));
|
27
|
-
var _fetch = require("./fetch");
|
28
|
-
var _clock = require("./clock");
|
29
|
-
var _socksClientCertificatesInterceptor = require("./socksClientCertificatesInterceptor");
|
30
|
-
var _recorderApp = require("./recorder/recorderApp");
|
31
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
32
|
-
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
33
|
-
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
34
|
-
/**
|
35
|
-
* Copyright 2017 Google Inc. All rights reserved.
|
36
|
-
* Modifications copyright (c) Microsoft Corporation.
|
37
|
-
*
|
38
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
39
|
-
* you may not use this file except in compliance with the License.
|
40
|
-
* You may obtain a copy of the License at
|
41
|
-
*
|
42
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
43
|
-
*
|
44
|
-
* Unless required by applicable law or agreed to in writing, software
|
45
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
46
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
47
|
-
* See the License for the specific language governing permissions and
|
48
|
-
* limitations under the License.
|
49
|
-
*/
|
50
|
-
|
51
|
-
class BrowserContext extends _instrumentation.SdkObject {
|
52
|
-
constructor(browser, options, browserContextId) {
|
53
|
-
super(browser, 'browser-context');
|
54
|
-
this._timeoutSettings = new _timeoutSettings.TimeoutSettings();
|
55
|
-
this._pageBindings = new Map();
|
56
|
-
this._activeProgressControllers = new Set();
|
57
|
-
this._options = void 0;
|
58
|
-
this._requestInterceptor = void 0;
|
59
|
-
this._isPersistentContext = void 0;
|
60
|
-
this._closedStatus = 'open';
|
61
|
-
this._closePromise = void 0;
|
62
|
-
this._closePromiseFulfill = void 0;
|
63
|
-
this._permissions = new Map();
|
64
|
-
this._downloads = new Set();
|
65
|
-
this._browser = void 0;
|
66
|
-
this._browserContextId = void 0;
|
67
|
-
this._selectors = void 0;
|
68
|
-
this._origins = new Set();
|
69
|
-
this._harRecorders = new Map();
|
70
|
-
this.tracing = void 0;
|
71
|
-
this.fetchRequest = void 0;
|
72
|
-
this._customCloseHandler = void 0;
|
73
|
-
this._tempDirs = [];
|
74
|
-
this._settingStorageState = false;
|
75
|
-
this.initScripts = [];
|
76
|
-
this._routesInFlight = new Set();
|
77
|
-
this._debugger = void 0;
|
78
|
-
this._closeReason = void 0;
|
79
|
-
this.clock = void 0;
|
80
|
-
this._clientCertificatesProxy = void 0;
|
81
|
-
this.attribution.context = this;
|
82
|
-
this._browser = browser;
|
83
|
-
this._options = options;
|
84
|
-
this._browserContextId = browserContextId;
|
85
|
-
this._isPersistentContext = !browserContextId;
|
86
|
-
this._closePromise = new Promise(fulfill => this._closePromiseFulfill = fulfill);
|
87
|
-
this.fetchRequest = new _fetch.BrowserContextAPIRequestContext(this);
|
88
|
-
if (this._options.recordHar) this._harRecorders.set('', new _harRecorder.HarRecorder(this, null, this._options.recordHar));
|
89
|
-
this.tracing = new _tracing.Tracing(this, browser.options.tracesDir);
|
90
|
-
this.clock = new _clock.Clock(this);
|
91
|
-
}
|
92
|
-
isPersistentContext() {
|
93
|
-
return this._isPersistentContext;
|
94
|
-
}
|
95
|
-
setSelectors(selectors) {
|
96
|
-
this._selectors = selectors;
|
97
|
-
}
|
98
|
-
selectors() {
|
99
|
-
return this._selectors || this.attribution.playwright.selectors;
|
100
|
-
}
|
101
|
-
async _initialize() {
|
102
|
-
if (this.attribution.playwright.options.isInternalPlaywright) return;
|
103
|
-
// Debugger will pause execution upon page.pause in headed mode.
|
104
|
-
this._debugger = new _debugger.Debugger(this);
|
105
|
-
|
106
|
-
// When PWDEBUG=1, show inspector for each context.
|
107
|
-
if ((0, _utils.debugMode)() === 'inspector') await _recorder.Recorder.show(this, _recorderApp.RecorderApp.factory(this), {
|
108
|
-
pauseOnNextStatement: true
|
109
|
-
});
|
110
|
-
|
111
|
-
// When paused, show inspector.
|
112
|
-
if (this._debugger.isPaused()) _recorder.Recorder.showInspector(this, _recorderApp.RecorderApp.factory(this));
|
113
|
-
this._debugger.on(_debugger.Debugger.Events.PausedStateChanged, () => {
|
114
|
-
if (this._debugger.isPaused()) _recorder.Recorder.showInspector(this, _recorderApp.RecorderApp.factory(this));
|
115
|
-
});
|
116
|
-
if ((0, _utils.debugMode)() === 'console') await this.extendInjectedScript(consoleApiSource.source);
|
117
|
-
if (this._options.serviceWorkers === 'block') await this.addInitScript(`\nif (navigator.serviceWorker) navigator.serviceWorker.register = async () => { console.warn('Service Worker registration blocked by Playwright'); };\n`);
|
118
|
-
if (this._options.permissions) await this.grantPermissions(this._options.permissions);
|
119
|
-
}
|
120
|
-
debugger() {
|
121
|
-
return this._debugger;
|
122
|
-
}
|
123
|
-
async _ensureVideosPath() {
|
124
|
-
if (this._options.recordVideo) await (0, _fileUtils.mkdirIfNeeded)(_path.default.join(this._options.recordVideo.dir, 'dummy'));
|
125
|
-
}
|
126
|
-
canResetForReuse() {
|
127
|
-
if (this._closedStatus !== 'open') return false;
|
128
|
-
return true;
|
129
|
-
}
|
130
|
-
async stopPendingOperations(reason) {
|
131
|
-
// When using context reuse, stop pending operations to gracefully terminate all the actions
|
132
|
-
// with a user-friendly error message containing operation log.
|
133
|
-
for (const controller of this._activeProgressControllers) controller.abort(new Error(reason));
|
134
|
-
// Let rejections in microtask generate events before returning.
|
135
|
-
await new Promise(f => setTimeout(f, 0));
|
136
|
-
}
|
137
|
-
static reusableContextHash(params) {
|
138
|
-
const paramsCopy = {
|
139
|
-
...params
|
140
|
-
};
|
141
|
-
for (const k of Object.keys(paramsCopy)) {
|
142
|
-
const key = k;
|
143
|
-
if (paramsCopy[key] === defaultNewContextParamValues[key]) delete paramsCopy[key];
|
144
|
-
}
|
145
|
-
for (const key of paramsThatAllowContextReuse) delete paramsCopy[key];
|
146
|
-
return JSON.stringify(paramsCopy);
|
147
|
-
}
|
148
|
-
async resetForReuse(metadata, params) {
|
149
|
-
var _page, _page2, _page3, _page4, _page5;
|
150
|
-
this.setDefaultNavigationTimeout(undefined);
|
151
|
-
this.setDefaultTimeout(undefined);
|
152
|
-
this.tracing.resetForReuse();
|
153
|
-
if (params) {
|
154
|
-
for (const key of paramsThatAllowContextReuse) this._options[key] = params[key];
|
155
|
-
}
|
156
|
-
await this._cancelAllRoutesInFlight();
|
157
|
-
|
158
|
-
// Close extra pages early.
|
159
|
-
let page = this.pages()[0];
|
160
|
-
const [, ...otherPages] = this.pages();
|
161
|
-
for (const p of otherPages) await p.close(metadata);
|
162
|
-
if (page && page.hasCrashed()) {
|
163
|
-
await page.close(metadata);
|
164
|
-
page = undefined;
|
165
|
-
}
|
166
|
-
|
167
|
-
// Unless dialogs are dismissed, setting extra http headers below does not respond.
|
168
|
-
(_page = page) === null || _page === void 0 || _page._frameManager.setCloseAllOpeningDialogs(true);
|
169
|
-
await ((_page2 = page) === null || _page2 === void 0 ? void 0 : _page2._frameManager.closeOpenDialogs());
|
170
|
-
// Navigate to about:blank first to ensure no page scripts are running after this point.
|
171
|
-
await ((_page3 = page) === null || _page3 === void 0 ? void 0 : _page3.mainFrame().goto(metadata, 'about:blank', {
|
172
|
-
timeout: 0
|
173
|
-
}));
|
174
|
-
(_page4 = page) === null || _page4 === void 0 || _page4._frameManager.setCloseAllOpeningDialogs(false);
|
175
|
-
await this._resetStorage();
|
176
|
-
await this._removeExposedBindings();
|
177
|
-
await this._removeInitScripts();
|
178
|
-
this.clock.markAsUninstalled();
|
179
|
-
// TODO: following can be optimized to not perform noops.
|
180
|
-
if (this._options.permissions) await this.grantPermissions(this._options.permissions);else await this.clearPermissions();
|
181
|
-
await this.setExtraHTTPHeaders(this._options.extraHTTPHeaders || []);
|
182
|
-
await this.setGeolocation(this._options.geolocation);
|
183
|
-
await this.setOffline(!!this._options.offline);
|
184
|
-
await this.setUserAgent(this._options.userAgent);
|
185
|
-
await this.clearCache();
|
186
|
-
await this._resetCookies();
|
187
|
-
await ((_page5 = page) === null || _page5 === void 0 ? void 0 : _page5.resetForReuse(metadata));
|
188
|
-
}
|
189
|
-
_browserClosed() {
|
190
|
-
for (const page of this.pages()) page._didClose();
|
191
|
-
this._didCloseInternal();
|
192
|
-
}
|
193
|
-
_didCloseInternal() {
|
194
|
-
var _this$_clientCertific;
|
195
|
-
if (this._closedStatus === 'closed') {
|
196
|
-
// We can come here twice if we close browser context and browser
|
197
|
-
// at the same time.
|
198
|
-
return;
|
199
|
-
}
|
200
|
-
(_this$_clientCertific = this._clientCertificatesProxy) === null || _this$_clientCertific === void 0 || _this$_clientCertific.close().catch(() => {});
|
201
|
-
this.tracing.abort();
|
202
|
-
if (this._isPersistentContext) this.onClosePersistent();
|
203
|
-
this._closePromiseFulfill(new Error('Context closed'));
|
204
|
-
this.emit(BrowserContext.Events.Close);
|
205
|
-
}
|
206
|
-
|
207
|
-
// BrowserContext methods.
|
208
|
-
|
209
|
-
async cookies(urls = []) {
|
210
|
-
if (urls && !Array.isArray(urls)) urls = [urls];
|
211
|
-
return await this.doGetCookies(urls);
|
212
|
-
}
|
213
|
-
async clearCookies(options) {
|
214
|
-
const currentCookies = await this.cookies();
|
215
|
-
await this.doClearCookies();
|
216
|
-
const matches = (cookie, prop, value) => {
|
217
|
-
if (!value) return true;
|
218
|
-
if (value instanceof RegExp) {
|
219
|
-
value.lastIndex = 0;
|
220
|
-
return value.test(cookie[prop]);
|
221
|
-
}
|
222
|
-
return cookie[prop] === value;
|
223
|
-
};
|
224
|
-
const cookiesToReadd = currentCookies.filter(cookie => {
|
225
|
-
return !matches(cookie, 'name', options.name) || !matches(cookie, 'domain', options.domain) || !matches(cookie, 'path', options.path);
|
226
|
-
});
|
227
|
-
await this.addCookies(cookiesToReadd);
|
228
|
-
}
|
229
|
-
setHTTPCredentials(httpCredentials) {
|
230
|
-
return this.doSetHTTPCredentials(httpCredentials);
|
231
|
-
}
|
232
|
-
async exposeBinding(name, needsHandle, playwrightBinding) {
|
233
|
-
if (this._pageBindings.has(name)) throw new Error(`Function "${name}" has been already registered`);
|
234
|
-
for (const page of this.pages()) {
|
235
|
-
if (page.getBinding(name)) throw new Error(`Function "${name}" has been already registered in one of the pages`);
|
236
|
-
}
|
237
|
-
const binding = new _page6.PageBinding(name, playwrightBinding, needsHandle);
|
238
|
-
this._pageBindings.set(name, binding);
|
239
|
-
await this.doAddInitScript(binding.initScript);
|
240
|
-
const frames = this.pages().map(page => page.frames()).flat();
|
241
|
-
await Promise.all(frames.map(frame => frame.evaluateExpression(binding.initScript.source).catch(e => {})));
|
242
|
-
}
|
243
|
-
async _removeExposedBindings() {
|
244
|
-
for (const [key, binding] of this._pageBindings) {
|
245
|
-
if (!binding.internal) this._pageBindings.delete(key);
|
246
|
-
}
|
247
|
-
}
|
248
|
-
async grantPermissions(permissions, origin) {
|
249
|
-
let resolvedOrigin = '*';
|
250
|
-
if (origin) {
|
251
|
-
const url = new URL(origin);
|
252
|
-
resolvedOrigin = url.origin;
|
253
|
-
}
|
254
|
-
const existing = new Set(this._permissions.get(resolvedOrigin) || []);
|
255
|
-
permissions.forEach(p => existing.add(p));
|
256
|
-
const list = [...existing.values()];
|
257
|
-
this._permissions.set(resolvedOrigin, list);
|
258
|
-
await this.doGrantPermissions(resolvedOrigin, list);
|
259
|
-
}
|
260
|
-
async clearPermissions() {
|
261
|
-
this._permissions.clear();
|
262
|
-
await this.doClearPermissions();
|
263
|
-
}
|
264
|
-
setDefaultNavigationTimeout(timeout) {
|
265
|
-
this._timeoutSettings.setDefaultNavigationTimeout(timeout);
|
266
|
-
}
|
267
|
-
setDefaultTimeout(timeout) {
|
268
|
-
this._timeoutSettings.setDefaultTimeout(timeout);
|
269
|
-
}
|
270
|
-
async _loadDefaultContextAsIs(progress) {
|
271
|
-
if (!this.pages().length) {
|
272
|
-
const waitForEvent = _helper.helper.waitForEvent(progress, this, BrowserContext.Events.Page);
|
273
|
-
progress.cleanupWhenAborted(() => waitForEvent.dispose);
|
274
|
-
const page = await waitForEvent.promise;
|
275
|
-
if (page._pageIsError) throw page._pageIsError;
|
276
|
-
}
|
277
|
-
const pages = this.pages();
|
278
|
-
if (pages[0]._pageIsError) throw pages[0]._pageIsError;
|
279
|
-
await pages[0].mainFrame()._waitForLoadState(progress, 'load');
|
280
|
-
return pages;
|
281
|
-
}
|
282
|
-
async _loadDefaultContext(progress) {
|
283
|
-
const pages = await this._loadDefaultContextAsIs(progress);
|
284
|
-
const browserName = this._browser.options.name;
|
285
|
-
if (this._options.isMobile && browserName === 'chromium' || this._options.locale && browserName === 'webkit') {
|
286
|
-
// Workaround for:
|
287
|
-
// - chromium fails to change isMobile for existing page;
|
288
|
-
// - webkit fails to change locale for existing page.
|
289
|
-
const oldPage = pages[0];
|
290
|
-
await this.newPage(progress.metadata);
|
291
|
-
await oldPage.close(progress.metadata);
|
292
|
-
}
|
293
|
-
}
|
294
|
-
_authenticateProxyViaHeader() {
|
295
|
-
const proxy = this._options.proxy || this._browser.options.proxy || {
|
296
|
-
username: undefined,
|
297
|
-
password: undefined
|
298
|
-
};
|
299
|
-
const {
|
300
|
-
username,
|
301
|
-
password
|
302
|
-
} = proxy;
|
303
|
-
if (username) {
|
304
|
-
this._options.httpCredentials = {
|
305
|
-
username,
|
306
|
-
password: password
|
307
|
-
};
|
308
|
-
const token = Buffer.from(`${username}:${password}`).toString('base64');
|
309
|
-
this._options.extraHTTPHeaders = network.mergeHeaders([this._options.extraHTTPHeaders, network.singleHeader('Proxy-Authorization', `Basic ${token}`)]);
|
310
|
-
}
|
311
|
-
}
|
312
|
-
_authenticateProxyViaCredentials() {
|
313
|
-
const proxy = this._options.proxy || this._browser.options.proxy;
|
314
|
-
if (!proxy) return;
|
315
|
-
const {
|
316
|
-
username,
|
317
|
-
password
|
318
|
-
} = proxy;
|
319
|
-
if (username) this._options.httpCredentials = {
|
320
|
-
username,
|
321
|
-
password: password || ''
|
322
|
-
};
|
323
|
-
}
|
324
|
-
async addInitScript(source) {
|
325
|
-
const initScript = new _page6.InitScript(source);
|
326
|
-
this.initScripts.push(initScript);
|
327
|
-
await this.doAddInitScript(initScript);
|
328
|
-
}
|
329
|
-
async _removeInitScripts() {
|
330
|
-
this.initScripts = this.initScripts.filter(script => script.internal);
|
331
|
-
await this.doRemoveNonInternalInitScripts();
|
332
|
-
}
|
333
|
-
async setRequestInterceptor(handler) {
|
334
|
-
this._requestInterceptor = handler;
|
335
|
-
await this.doUpdateRequestInterception();
|
336
|
-
}
|
337
|
-
isClosingOrClosed() {
|
338
|
-
return this._closedStatus !== 'open';
|
339
|
-
}
|
340
|
-
async _deleteAllDownloads() {
|
341
|
-
await Promise.all(Array.from(this._downloads).map(download => download.artifact.deleteOnContextClose()));
|
342
|
-
}
|
343
|
-
async _deleteAllTempDirs() {
|
344
|
-
await Promise.all(this._tempDirs.map(async dir => await _fs.default.promises.unlink(dir).catch(e => {})));
|
345
|
-
}
|
346
|
-
setCustomCloseHandler(handler) {
|
347
|
-
this._customCloseHandler = handler;
|
348
|
-
}
|
349
|
-
async close(options) {
|
350
|
-
if (this._closedStatus === 'open') {
|
351
|
-
if (options.reason) this._closeReason = options.reason;
|
352
|
-
this.emit(BrowserContext.Events.BeforeClose);
|
353
|
-
this._closedStatus = 'closing';
|
354
|
-
for (const harRecorder of this._harRecorders.values()) await harRecorder.flush();
|
355
|
-
await this.tracing.flush();
|
356
|
-
|
357
|
-
// Cleanup.
|
358
|
-
const promises = [];
|
359
|
-
for (const {
|
360
|
-
context,
|
361
|
-
artifact
|
362
|
-
} of this._browser._idToVideo.values()) {
|
363
|
-
// Wait for the videos to finish.
|
364
|
-
if (context === this) promises.push(artifact.finishedPromise());
|
365
|
-
}
|
366
|
-
if (this._customCloseHandler) {
|
367
|
-
await this._customCloseHandler();
|
368
|
-
} else {
|
369
|
-
// Close the context.
|
370
|
-
await this.doClose(options.reason);
|
371
|
-
}
|
372
|
-
|
373
|
-
// We delete downloads after context closure
|
374
|
-
// so that browser does not write to the download file anymore.
|
375
|
-
promises.push(this._deleteAllDownloads());
|
376
|
-
promises.push(this._deleteAllTempDirs());
|
377
|
-
await Promise.all(promises);
|
378
|
-
|
379
|
-
// Custom handler should trigger didCloseInternal itself.
|
380
|
-
if (!this._customCloseHandler) this._didCloseInternal();
|
381
|
-
}
|
382
|
-
await this._closePromise;
|
383
|
-
}
|
384
|
-
async newPage(metadata) {
|
385
|
-
const pageDelegate = await this.newPageDelegate();
|
386
|
-
if (metadata.isServerSide) pageDelegate.potentiallyUninitializedPage().markAsServerSideOnly();
|
387
|
-
const pageOrError = await pageDelegate.pageOrError();
|
388
|
-
if (pageOrError instanceof _page6.Page) {
|
389
|
-
if (pageOrError.isClosed()) throw new Error('Page has been closed.');
|
390
|
-
return pageOrError;
|
391
|
-
}
|
392
|
-
throw pageOrError;
|
393
|
-
}
|
394
|
-
addVisitedOrigin(origin) {
|
395
|
-
this._origins.add(origin);
|
396
|
-
}
|
397
|
-
async storageState() {
|
398
|
-
const result = {
|
399
|
-
cookies: await this.cookies(),
|
400
|
-
origins: []
|
401
|
-
};
|
402
|
-
const originsToSave = new Set(this._origins);
|
403
|
-
|
404
|
-
// First try collecting storage stage from existing pages.
|
405
|
-
for (const page of this.pages()) {
|
406
|
-
const origin = page.mainFrame().origin();
|
407
|
-
if (!origin || !originsToSave.has(origin)) continue;
|
408
|
-
try {
|
409
|
-
const storage = await page.mainFrame().nonStallingEvaluateInExistingContext(`({
|
410
|
-
localStorage: Object.keys(localStorage).map(name => ({ name, value: localStorage.getItem(name) })),
|
411
|
-
})`, 'utility');
|
412
|
-
if (storage.localStorage.length) result.origins.push({
|
413
|
-
origin,
|
414
|
-
localStorage: storage.localStorage
|
415
|
-
});
|
416
|
-
originsToSave.delete(origin);
|
417
|
-
} catch {
|
418
|
-
// When failed on the live page, we'll retry on the blank page below.
|
419
|
-
}
|
420
|
-
}
|
421
|
-
|
422
|
-
// If there are still origins to save, create a blank page to iterate over origins.
|
423
|
-
if (originsToSave.size) {
|
424
|
-
const internalMetadata = (0, _instrumentation.serverSideCallMetadata)();
|
425
|
-
const page = await this.newPage(internalMetadata);
|
426
|
-
await page._setServerRequestInterceptor(handler => {
|
427
|
-
handler.fulfill({
|
428
|
-
body: '<html></html>',
|
429
|
-
requestUrl: handler.request().url()
|
430
|
-
}).catch(() => {});
|
431
|
-
return true;
|
432
|
-
});
|
433
|
-
for (const origin of originsToSave) {
|
434
|
-
const originStorage = {
|
435
|
-
origin,
|
436
|
-
localStorage: []
|
437
|
-
};
|
438
|
-
const frame = page.mainFrame();
|
439
|
-
await frame.goto(internalMetadata, origin);
|
440
|
-
const storage = await frame.evaluateExpression(`({
|
441
|
-
localStorage: Object.keys(localStorage).map(name => ({ name, value: localStorage.getItem(name) })),
|
442
|
-
})`, {
|
443
|
-
world: 'utility'
|
444
|
-
});
|
445
|
-
originStorage.localStorage = storage.localStorage;
|
446
|
-
if (storage.localStorage.length) result.origins.push(originStorage);
|
447
|
-
}
|
448
|
-
await page.close(internalMetadata);
|
449
|
-
}
|
450
|
-
return result;
|
451
|
-
}
|
452
|
-
async _resetStorage() {
|
453
|
-
var _this$_options$storag;
|
454
|
-
const oldOrigins = this._origins;
|
455
|
-
const newOrigins = new Map(((_this$_options$storag = this._options.storageState) === null || _this$_options$storag === void 0 || (_this$_options$storag = _this$_options$storag.origins) === null || _this$_options$storag === void 0 ? void 0 : _this$_options$storag.map(p => [p.origin, p])) || []);
|
456
|
-
if (!oldOrigins.size && !newOrigins.size) return;
|
457
|
-
let page = this.pages()[0];
|
458
|
-
const internalMetadata = (0, _instrumentation.serverSideCallMetadata)();
|
459
|
-
page = page || (await this.newPage({
|
460
|
-
...internalMetadata,
|
461
|
-
// Do not mark this page as internal, because we will leave it for later reuse
|
462
|
-
// as a user-visible page.
|
463
|
-
isServerSide: false
|
464
|
-
}));
|
465
|
-
await page._setServerRequestInterceptor(handler => {
|
466
|
-
handler.fulfill({
|
467
|
-
body: '<html></html>',
|
468
|
-
requestUrl: handler.request().url()
|
469
|
-
}).catch(() => {});
|
470
|
-
return true;
|
471
|
-
});
|
472
|
-
for (const origin of new Set([...oldOrigins, ...newOrigins.keys()])) {
|
473
|
-
const frame = page.mainFrame();
|
474
|
-
await frame.goto(internalMetadata, origin);
|
475
|
-
await frame.resetStorageForCurrentOriginBestEffort(newOrigins.get(origin));
|
476
|
-
}
|
477
|
-
await page._setServerRequestInterceptor(undefined);
|
478
|
-
this._origins = new Set([...newOrigins.keys()]);
|
479
|
-
// It is safe to not restore the URL to about:blank since we are doing it in Page::resetForReuse.
|
480
|
-
}
|
481
|
-
async _resetCookies() {
|
482
|
-
var _this$_options$storag2, _this$_options$storag3;
|
483
|
-
await this.doClearCookies();
|
484
|
-
if ((_this$_options$storag2 = this._options.storageState) !== null && _this$_options$storag2 !== void 0 && _this$_options$storag2.cookies) await this.addCookies((_this$_options$storag3 = this._options.storageState) === null || _this$_options$storag3 === void 0 ? void 0 : _this$_options$storag3.cookies);
|
485
|
-
}
|
486
|
-
isSettingStorageState() {
|
487
|
-
return this._settingStorageState;
|
488
|
-
}
|
489
|
-
async setStorageState(metadata, state) {
|
490
|
-
this._settingStorageState = true;
|
491
|
-
try {
|
492
|
-
if (state.cookies) await this.addCookies(state.cookies);
|
493
|
-
if (state.origins && state.origins.length) {
|
494
|
-
const internalMetadata = (0, _instrumentation.serverSideCallMetadata)();
|
495
|
-
const page = await this.newPage(internalMetadata);
|
496
|
-
await page._setServerRequestInterceptor(handler => {
|
497
|
-
handler.fulfill({
|
498
|
-
body: '<html></html>',
|
499
|
-
requestUrl: handler.request().url()
|
500
|
-
}).catch(() => {});
|
501
|
-
return true;
|
502
|
-
});
|
503
|
-
for (const originState of state.origins) {
|
504
|
-
const frame = page.mainFrame();
|
505
|
-
await frame.goto(metadata, originState.origin);
|
506
|
-
await frame.evaluateExpression(`
|
507
|
-
originState => {
|
508
|
-
for (const { name, value } of (originState.localStorage || []))
|
509
|
-
localStorage.setItem(name, value);
|
510
|
-
}`, {
|
511
|
-
isFunction: true,
|
512
|
-
world: 'utility'
|
513
|
-
}, originState);
|
514
|
-
}
|
515
|
-
await page.close(internalMetadata);
|
516
|
-
}
|
517
|
-
} finally {
|
518
|
-
this._settingStorageState = false;
|
519
|
-
}
|
520
|
-
}
|
521
|
-
async extendInjectedScript(source, arg) {
|
522
|
-
const installInFrame = frame => frame.extendInjectedScript(source, arg).catch(() => {});
|
523
|
-
const installInPage = page => {
|
524
|
-
page.on(_page6.Page.Events.InternalFrameNavigatedToNewDocument, installInFrame);
|
525
|
-
return Promise.all(page.frames().map(installInFrame));
|
526
|
-
};
|
527
|
-
this.on(BrowserContext.Events.Page, installInPage);
|
528
|
-
return Promise.all(this.pages().map(installInPage));
|
529
|
-
}
|
530
|
-
async safeNonStallingEvaluateInAllFrames(expression, world, options = {}) {
|
531
|
-
await Promise.all(this.pages().map(page => page.safeNonStallingEvaluateInAllFrames(expression, world, options)));
|
532
|
-
}
|
533
|
-
async _harStart(page, options) {
|
534
|
-
const harId = (0, _utils.createGuid)();
|
535
|
-
this._harRecorders.set(harId, new _harRecorder.HarRecorder(this, page, options));
|
536
|
-
return harId;
|
537
|
-
}
|
538
|
-
async _harExport(harId) {
|
539
|
-
const recorder = this._harRecorders.get(harId || '');
|
540
|
-
return recorder.export();
|
541
|
-
}
|
542
|
-
addRouteInFlight(route) {
|
543
|
-
this._routesInFlight.add(route);
|
544
|
-
}
|
545
|
-
removeRouteInFlight(route) {
|
546
|
-
this._routesInFlight.delete(route);
|
547
|
-
}
|
548
|
-
async _cancelAllRoutesInFlight() {
|
549
|
-
await Promise.all([...this._routesInFlight].map(r => r.abort())).catch(() => {});
|
550
|
-
this._routesInFlight.clear();
|
551
|
-
}
|
552
|
-
}
|
553
|
-
exports.BrowserContext = BrowserContext;
|
554
|
-
BrowserContext.Events = {
|
555
|
-
Console: 'console',
|
556
|
-
Close: 'close',
|
557
|
-
Dialog: 'dialog',
|
558
|
-
Page: 'page',
|
559
|
-
// Can't use just 'error' due to node.js special treatment of error events.
|
560
|
-
// @see https://nodejs.org/api/events.html#events_error_events
|
561
|
-
PageError: 'pageerror',
|
562
|
-
Request: 'request',
|
563
|
-
Response: 'response',
|
564
|
-
RequestFailed: 'requestfailed',
|
565
|
-
RequestFinished: 'requestfinished',
|
566
|
-
RequestAborted: 'requestaborted',
|
567
|
-
RequestFulfilled: 'requestfulfilled',
|
568
|
-
RequestContinued: 'requestcontinued',
|
569
|
-
BeforeClose: 'beforeclose',
|
570
|
-
VideoStarted: 'videostarted'
|
571
|
-
};
|
572
|
-
function assertBrowserContextIsNotOwned(context) {
|
573
|
-
for (const page of context.pages()) {
|
574
|
-
if (page._ownedContext) throw new Error('Please use browser.newContext() for multi-page scripts that share the context.');
|
575
|
-
}
|
576
|
-
}
|
577
|
-
async function createClientCertificatesProxyIfNeeded(options, browserOptions) {
|
578
|
-
var _options$clientCertif, _options$proxy, _options$proxy2, _browserOptions$proxy, _browserOptions$proxy2;
|
579
|
-
if (!((_options$clientCertif = options.clientCertificates) !== null && _options$clientCertif !== void 0 && _options$clientCertif.length)) return;
|
580
|
-
if ((_options$proxy = options.proxy) !== null && _options$proxy !== void 0 && _options$proxy.server && ((_options$proxy2 = options.proxy) === null || _options$proxy2 === void 0 ? void 0 : _options$proxy2.server) !== 'per-context' || browserOptions !== null && browserOptions !== void 0 && (_browserOptions$proxy = browserOptions.proxy) !== null && _browserOptions$proxy !== void 0 && _browserOptions$proxy.server && (browserOptions === null || browserOptions === void 0 || (_browserOptions$proxy2 = browserOptions.proxy) === null || _browserOptions$proxy2 === void 0 ? void 0 : _browserOptions$proxy2.server) !== 'http://per-context') throw new Error('Cannot specify both proxy and clientCertificates');
|
581
|
-
verifyClientCertificates(options.clientCertificates);
|
582
|
-
const clientCertificatesProxy = new _socksClientCertificatesInterceptor.ClientCertificatesProxy(options);
|
583
|
-
options.proxy = {
|
584
|
-
server: await clientCertificatesProxy.listen()
|
585
|
-
};
|
586
|
-
options.ignoreHTTPSErrors = true;
|
587
|
-
return clientCertificatesProxy;
|
588
|
-
}
|
589
|
-
function validateBrowserContextOptions(options, browserOptions) {
|
590
|
-
if (options.noDefaultViewport && options.deviceScaleFactor !== undefined) throw new Error(`"deviceScaleFactor" option is not supported with null "viewport"`);
|
591
|
-
if (options.noDefaultViewport && !!options.isMobile) throw new Error(`"isMobile" option is not supported with null "viewport"`);
|
592
|
-
if (options.acceptDownloads === undefined && browserOptions.name !== 'electron') options.acceptDownloads = 'accept';
|
593
|
-
// Electron requires explicit acceptDownloads: true since we wait for
|
594
|
-
// https://github.com/electron/electron/pull/41718 to be widely shipped.
|
595
|
-
// In 6-12 months, we can remove this check.
|
596
|
-
else if (options.acceptDownloads === undefined && browserOptions.name === 'electron') options.acceptDownloads = 'internal-browser-default';
|
597
|
-
if (!options.viewport && !options.noDefaultViewport) options.viewport = {
|
598
|
-
width: 1280,
|
599
|
-
height: 720
|
600
|
-
};
|
601
|
-
if (options.recordVideo) {
|
602
|
-
if (!options.recordVideo.size) {
|
603
|
-
if (options.noDefaultViewport) {
|
604
|
-
options.recordVideo.size = {
|
605
|
-
width: 800,
|
606
|
-
height: 600
|
607
|
-
};
|
608
|
-
} else {
|
609
|
-
const size = options.viewport;
|
610
|
-
const scale = Math.min(1, 800 / Math.max(size.width, size.height));
|
611
|
-
options.recordVideo.size = {
|
612
|
-
width: Math.floor(size.width * scale),
|
613
|
-
height: Math.floor(size.height * scale)
|
614
|
-
};
|
615
|
-
}
|
616
|
-
}
|
617
|
-
// Make sure both dimensions are odd, this is required for vp8
|
618
|
-
options.recordVideo.size.width &= ~1;
|
619
|
-
options.recordVideo.size.height &= ~1;
|
620
|
-
}
|
621
|
-
if (options.proxy) options.proxy = normalizeProxySettings(options.proxy);
|
622
|
-
verifyGeolocation(options.geolocation);
|
623
|
-
}
|
624
|
-
function verifyGeolocation(geolocation) {
|
625
|
-
if (!geolocation) return;
|
626
|
-
geolocation.accuracy = geolocation.accuracy || 0;
|
627
|
-
const {
|
628
|
-
longitude,
|
629
|
-
latitude,
|
630
|
-
accuracy
|
631
|
-
} = geolocation;
|
632
|
-
if (longitude < -180 || longitude > 180) throw new Error(`geolocation.longitude: precondition -180 <= LONGITUDE <= 180 failed.`);
|
633
|
-
if (latitude < -90 || latitude > 90) throw new Error(`geolocation.latitude: precondition -90 <= LATITUDE <= 90 failed.`);
|
634
|
-
if (accuracy < 0) throw new Error(`geolocation.accuracy: precondition 0 <= ACCURACY failed.`);
|
635
|
-
}
|
636
|
-
function verifyClientCertificates(clientCertificates) {
|
637
|
-
if (!clientCertificates) return;
|
638
|
-
for (const cert of clientCertificates) {
|
639
|
-
if (!cert.origin) throw new Error(`clientCertificates.origin is required`);
|
640
|
-
if (!cert.cert && !cert.key && !cert.passphrase && !cert.pfx) throw new Error('None of cert, key, passphrase or pfx is specified');
|
641
|
-
if (cert.cert && !cert.key) throw new Error('cert is specified without key');
|
642
|
-
if (!cert.cert && cert.key) throw new Error('key is specified without cert');
|
643
|
-
if (cert.pfx && (cert.cert || cert.key)) throw new Error('pfx is specified together with cert, key or passphrase');
|
644
|
-
}
|
645
|
-
}
|
646
|
-
function normalizeProxySettings(proxy) {
|
647
|
-
let {
|
648
|
-
server,
|
649
|
-
bypass
|
650
|
-
} = proxy;
|
651
|
-
let url;
|
652
|
-
try {
|
653
|
-
// new URL('127.0.0.1:8080') throws
|
654
|
-
// new URL('localhost:8080') fails to parse host or protocol
|
655
|
-
// In both of these cases, we need to try re-parse URL with `http://` prefix.
|
656
|
-
url = new URL(server);
|
657
|
-
if (!url.host || !url.protocol) url = new URL('http://' + server);
|
658
|
-
} catch (e) {
|
659
|
-
url = new URL('http://' + server);
|
660
|
-
}
|
661
|
-
if (url.protocol === 'socks4:' && (proxy.username || proxy.password)) throw new Error(`Socks4 proxy protocol does not support authentication`);
|
662
|
-
if (url.protocol === 'socks5:' && (proxy.username || proxy.password)) throw new Error(`Browser does not support socks5 proxy authentication`);
|
663
|
-
server = url.protocol + '//' + url.host;
|
664
|
-
if (bypass) bypass = bypass.split(',').map(t => t.trim()).join(',');
|
665
|
-
return {
|
666
|
-
...proxy,
|
667
|
-
server,
|
668
|
-
bypass
|
669
|
-
};
|
670
|
-
}
|
671
|
-
const paramsThatAllowContextReuse = ['colorScheme', 'forcedColors', 'reducedMotion', 'screen', 'userAgent', 'viewport'];
|
672
|
-
const defaultNewContextParamValues = {
|
673
|
-
noDefaultViewport: false,
|
674
|
-
ignoreHTTPSErrors: false,
|
675
|
-
javaScriptEnabled: true,
|
676
|
-
bypassCSP: false,
|
677
|
-
offline: false,
|
678
|
-
isMobile: false,
|
679
|
-
hasTouch: false,
|
680
|
-
acceptDownloads: 'accept',
|
681
|
-
strictSelectors: false,
|
682
|
-
serviceWorkers: 'allow',
|
683
|
-
locale: 'en-US'
|
684
|
-
};
|