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,179 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
6
|
-
exports.locatorOrSelectorAsSelector = locatorOrSelectorAsSelector;
|
7
|
-
var _stringUtils = require("./stringUtils");
|
8
|
-
var _locatorGenerators = require("./locatorGenerators");
|
9
|
-
var _selectorParser = require("./selectorParser");
|
10
|
-
/**
|
11
|
-
* Copyright (c) Microsoft Corporation.
|
12
|
-
*
|
13
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
14
|
-
* you may not use this file except in compliance with the License.
|
15
|
-
* You may obtain a copy of the License at
|
16
|
-
*
|
17
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
18
|
-
*
|
19
|
-
* Unless required by applicable law or agreed to in writing, software
|
20
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
21
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
22
|
-
* See the License for the specific language governing permissions and
|
23
|
-
* limitations under the License.
|
24
|
-
*/
|
25
|
-
|
26
|
-
function parseLocator(locator, testIdAttributeName) {
|
27
|
-
locator = locator.replace(/AriaRole\s*\.\s*([\w]+)/g, (_, group) => group.toLowerCase()).replace(/(get_by_role|getByRole)\s*\(\s*(?:["'`])([^'"`]+)['"`]/g, (_, group1, group2) => `${group1}(${group2.toLowerCase()}`);
|
28
|
-
const params = [];
|
29
|
-
let template = '';
|
30
|
-
for (let i = 0; i < locator.length; ++i) {
|
31
|
-
const quote = locator[i];
|
32
|
-
if (quote !== '"' && quote !== '\'' && quote !== '`' && quote !== '/') {
|
33
|
-
template += quote;
|
34
|
-
continue;
|
35
|
-
}
|
36
|
-
const isRegexEscaping = locator[i - 1] === 'r' || locator[i] === '/';
|
37
|
-
++i;
|
38
|
-
let text = '';
|
39
|
-
while (i < locator.length) {
|
40
|
-
if (locator[i] === '\\') {
|
41
|
-
if (isRegexEscaping) {
|
42
|
-
if (locator[i + 1] !== quote) text += locator[i];
|
43
|
-
++i;
|
44
|
-
text += locator[i];
|
45
|
-
} else {
|
46
|
-
++i;
|
47
|
-
if (locator[i] === 'n') text += '\n';else if (locator[i] === 'r') text += '\r';else if (locator[i] === 't') text += '\t';else text += locator[i];
|
48
|
-
}
|
49
|
-
++i;
|
50
|
-
continue;
|
51
|
-
}
|
52
|
-
if (locator[i] !== quote) {
|
53
|
-
text += locator[i++];
|
54
|
-
continue;
|
55
|
-
}
|
56
|
-
break;
|
57
|
-
}
|
58
|
-
params.push({
|
59
|
-
quote,
|
60
|
-
text
|
61
|
-
});
|
62
|
-
template += (quote === '/' ? 'r' : '') + '$' + params.length;
|
63
|
-
}
|
64
|
-
|
65
|
-
// Equalize languages.
|
66
|
-
template = template.toLowerCase().replace(/get_by_alt_text/g, 'getbyalttext').replace(/get_by_test_id/g, 'getbytestid').replace(/get_by_([\w]+)/g, 'getby$1').replace(/has_not_text/g, 'hasnottext').replace(/has_text/g, 'hastext').replace(/has_not/g, 'hasnot').replace(/frame_locator/g, 'framelocator').replace(/[{}\s]/g, '').replace(/new\(\)/g, '').replace(/new[\w]+\.[\w]+options\(\)/g, '').replace(/\.set/g, ',set').replace(/\.or_\(/g, 'or(') // Python has "or_" instead of "or".
|
67
|
-
.replace(/\.and_\(/g, 'and(') // Python has "and_" instead of "and".
|
68
|
-
.replace(/:/g, '=').replace(/,re\.ignorecase/g, 'i').replace(/,pattern.case_insensitive/g, 'i').replace(/,regexoptions.ignorecase/g, 'i').replace(/re.compile\(([^)]+)\)/g, '$1') // Python has regex strings as r"foo"
|
69
|
-
.replace(/pattern.compile\(([^)]+)\)/g, 'r$1').replace(/newregex\(([^)]+)\)/g, 'r$1').replace(/string=/g, '=').replace(/regex=/g, '=').replace(/,,/g, ',');
|
70
|
-
const preferredQuote = params.map(p => p.quote).filter(quote => '\'"`'.includes(quote))[0];
|
71
|
-
return {
|
72
|
-
selector: transform(template, params, testIdAttributeName),
|
73
|
-
preferredQuote
|
74
|
-
};
|
75
|
-
}
|
76
|
-
function countParams(template) {
|
77
|
-
return [...template.matchAll(/\$\d+/g)].length;
|
78
|
-
}
|
79
|
-
function shiftParams(template, sub) {
|
80
|
-
return template.replace(/\$(\d+)/g, (_, ordinal) => `$${ordinal - sub}`);
|
81
|
-
}
|
82
|
-
function transform(template, params, testIdAttributeName) {
|
83
|
-
// Recursively handle filter(has=, hasnot=, sethas(), sethasnot()).
|
84
|
-
// TODO: handle and(locator), or(locator), locator(locator), locator(has=, hasnot=, sethas(), sethasnot()).
|
85
|
-
while (true) {
|
86
|
-
const hasMatch = template.match(/filter\(,?(has=|hasnot=|sethas\(|sethasnot\()/);
|
87
|
-
if (!hasMatch) break;
|
88
|
-
|
89
|
-
// Extract inner locator based on balanced parens.
|
90
|
-
const start = hasMatch.index + hasMatch[0].length;
|
91
|
-
let balance = 0;
|
92
|
-
let end = start;
|
93
|
-
for (; end < template.length; end++) {
|
94
|
-
if (template[end] === '(') balance++;else if (template[end] === ')') balance--;
|
95
|
-
if (balance < 0) break;
|
96
|
-
}
|
97
|
-
|
98
|
-
// Replace Java sethas(...) and sethasnot(...) with has=... and hasnot=...
|
99
|
-
let prefix = template.substring(0, start);
|
100
|
-
let extraSymbol = 0;
|
101
|
-
if (['sethas(', 'sethasnot('].includes(hasMatch[1])) {
|
102
|
-
// Eat extra ) symbol at the end of sethas(...)
|
103
|
-
extraSymbol = 1;
|
104
|
-
prefix = prefix.replace(/sethas\($/, 'has=').replace(/sethasnot\($/, 'hasnot=');
|
105
|
-
}
|
106
|
-
const paramsCountBeforeHas = countParams(template.substring(0, start));
|
107
|
-
const hasTemplate = shiftParams(template.substring(start, end), paramsCountBeforeHas);
|
108
|
-
const paramsCountInHas = countParams(hasTemplate);
|
109
|
-
const hasParams = params.slice(paramsCountBeforeHas, paramsCountBeforeHas + paramsCountInHas);
|
110
|
-
const hasSelector = JSON.stringify(transform(hasTemplate, hasParams, testIdAttributeName));
|
111
|
-
|
112
|
-
// Replace filter(has=...) with filter(has2=$5). Use has2 to avoid matching the same filter again.
|
113
|
-
// Replace filter(hasnot=...) with filter(hasnot2=$5). Use hasnot2 to avoid matching the same filter again.
|
114
|
-
template = prefix.replace(/=$/, '2=') + `$${paramsCountBeforeHas + 1}` + shiftParams(template.substring(end + extraSymbol), paramsCountInHas - 1);
|
115
|
-
|
116
|
-
// Replace inner params with $5 value.
|
117
|
-
const paramsBeforeHas = params.slice(0, paramsCountBeforeHas);
|
118
|
-
const paramsAfterHas = params.slice(paramsCountBeforeHas + paramsCountInHas);
|
119
|
-
params = paramsBeforeHas.concat([{
|
120
|
-
quote: '"',
|
121
|
-
text: hasSelector
|
122
|
-
}]).concat(paramsAfterHas);
|
123
|
-
}
|
124
|
-
|
125
|
-
// Transform to selector engines.
|
126
|
-
template = template.replace(/\,set([\w]+)\(([^)]+)\)/g, (_, group1, group2) => ',' + group1.toLowerCase() + '=' + group2.toLowerCase()).replace(/framelocator\(([^)]+)\)/g, '$1.internal:control=enter-frame').replace(/locator\(([^)]+),hastext=([^),]+)\)/g, 'locator($1).internal:has-text=$2').replace(/locator\(([^)]+),hasnottext=([^),]+)\)/g, 'locator($1).internal:has-not-text=$2').replace(/locator\(([^)]+),hastext=([^),]+)\)/g, 'locator($1).internal:has-text=$2').replace(/locator\(([^)]+)\)/g, '$1').replace(/getbyrole\(([^)]+)\)/g, 'internal:role=$1').replace(/getbytext\(([^)]+)\)/g, 'internal:text=$1').replace(/getbylabel\(([^)]+)\)/g, 'internal:label=$1').replace(/getbytestid\(([^)]+)\)/g, `internal:testid=[${testIdAttributeName}=$1]`).replace(/getby(placeholder|alt|title)(?:text)?\(([^)]+)\)/g, 'internal:attr=[$1=$2]').replace(/first(\(\))?/g, 'nth=0').replace(/last(\(\))?/g, 'nth=-1').replace(/nth\(([^)]+)\)/g, 'nth=$1').replace(/filter\(,?hastext=([^)]+)\)/g, 'internal:has-text=$1').replace(/filter\(,?hasnottext=([^)]+)\)/g, 'internal:has-not-text=$1').replace(/filter\(,?has2=([^)]+)\)/g, 'internal:has=$1').replace(/filter\(,?hasnot2=([^)]+)\)/g, 'internal:has-not=$1').replace(/,exact=false/g, '').replace(/,exact=true/g, 's').replace(/\,/g, '][');
|
127
|
-
const parts = template.split('.');
|
128
|
-
// Turn "internal:control=enter-frame >> nth=0" into "nth=0 >> internal:control=enter-frame"
|
129
|
-
// because these are swapped in locators vs selectors.
|
130
|
-
for (let index = 0; index < parts.length - 1; index++) {
|
131
|
-
if (parts[index] === 'internal:control=enter-frame' && parts[index + 1].startsWith('nth=')) {
|
132
|
-
// Swap nth and enter-frame.
|
133
|
-
const [nth] = parts.splice(index, 1);
|
134
|
-
parts.splice(index + 1, 0, nth);
|
135
|
-
}
|
136
|
-
}
|
137
|
-
|
138
|
-
// Substitute params.
|
139
|
-
return parts.map(t => {
|
140
|
-
if (!t.startsWith('internal:') || t === 'internal:control') return t.replace(/\$(\d+)/g, (_, ordinal) => {
|
141
|
-
const param = params[+ordinal - 1];
|
142
|
-
return param.text;
|
143
|
-
});
|
144
|
-
t = t.includes('[') ? t.replace(/\]/, '') + ']' : t;
|
145
|
-
t = t.replace(/(?:r)\$(\d+)(i)?/g, (_, ordinal, suffix) => {
|
146
|
-
const param = params[+ordinal - 1];
|
147
|
-
if (t.startsWith('internal:attr') || t.startsWith('internal:testid') || t.startsWith('internal:role')) return (0, _stringUtils.escapeForAttributeSelector)(new RegExp(param.text), false) + (suffix || '');
|
148
|
-
return (0, _stringUtils.escapeForTextSelector)(new RegExp(param.text, suffix), false);
|
149
|
-
}).replace(/\$(\d+)(i|s)?/g, (_, ordinal, suffix) => {
|
150
|
-
const param = params[+ordinal - 1];
|
151
|
-
if (t.startsWith('internal:has=') || t.startsWith('internal:has-not=')) return param.text;
|
152
|
-
if (t.startsWith('internal:testid')) return (0, _stringUtils.escapeForAttributeSelector)(param.text, true);
|
153
|
-
if (t.startsWith('internal:attr') || t.startsWith('internal:role')) return (0, _stringUtils.escapeForAttributeSelector)(param.text, suffix === 's');
|
154
|
-
return (0, _stringUtils.escapeForTextSelector)(param.text, suffix === 's');
|
155
|
-
});
|
156
|
-
return t;
|
157
|
-
}).join(' >> ');
|
158
|
-
}
|
159
|
-
function locatorOrSelectorAsSelector(language, locator, testIdAttributeName) {
|
160
|
-
try {
|
161
|
-
(0, _selectorParser.parseSelector)(locator);
|
162
|
-
return locator;
|
163
|
-
} catch (e) {}
|
164
|
-
try {
|
165
|
-
const {
|
166
|
-
selector,
|
167
|
-
preferredQuote
|
168
|
-
} = parseLocator(locator, testIdAttributeName);
|
169
|
-
const locators = (0, _locatorGenerators.asLocators)(language, selector, undefined, undefined, preferredQuote);
|
170
|
-
const digest = digestForComparison(language, locator);
|
171
|
-
if (locators.some(candidate => digestForComparison(language, candidate) === digest)) return selector;
|
172
|
-
} catch (e) {}
|
173
|
-
return '';
|
174
|
-
}
|
175
|
-
function digestForComparison(language, locator) {
|
176
|
-
locator = locator.replace(/\s/g, '');
|
177
|
-
if (language === 'javascript') locator = locator.replace(/\\?["`]/g, '\'');
|
178
|
-
return locator;
|
179
|
-
}
|
@@ -1,62 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
6
|
-
exports.getByAltTextSelector = getByAltTextSelector;
|
7
|
-
exports.getByLabelSelector = getByLabelSelector;
|
8
|
-
exports.getByPlaceholderSelector = getByPlaceholderSelector;
|
9
|
-
exports.getByRoleSelector = getByRoleSelector;
|
10
|
-
exports.getByTestIdSelector = getByTestIdSelector;
|
11
|
-
exports.getByTextSelector = getByTextSelector;
|
12
|
-
exports.getByTitleSelector = getByTitleSelector;
|
13
|
-
var _stringUtils = require("./stringUtils");
|
14
|
-
/**
|
15
|
-
* Copyright (c) Microsoft Corporation.
|
16
|
-
*
|
17
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
18
|
-
* you may not use this file except in compliance with the License.
|
19
|
-
* You may obtain a copy of the License at
|
20
|
-
*
|
21
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
22
|
-
*
|
23
|
-
* Unless required by applicable law or agreed to in writing, software
|
24
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
25
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
26
|
-
* See the License for the specific language governing permissions and
|
27
|
-
* limitations under the License.
|
28
|
-
*/
|
29
|
-
|
30
|
-
function getByAttributeTextSelector(attrName, text, options) {
|
31
|
-
return `internal:attr=[${attrName}=${(0, _stringUtils.escapeForAttributeSelector)(text, (options === null || options === void 0 ? void 0 : options.exact) || false)}]`;
|
32
|
-
}
|
33
|
-
function getByTestIdSelector(testIdAttributeName, testId) {
|
34
|
-
return `internal:testid=[${testIdAttributeName}=${(0, _stringUtils.escapeForAttributeSelector)(testId, true)}]`;
|
35
|
-
}
|
36
|
-
function getByLabelSelector(text, options) {
|
37
|
-
return 'internal:label=' + (0, _stringUtils.escapeForTextSelector)(text, !!(options !== null && options !== void 0 && options.exact));
|
38
|
-
}
|
39
|
-
function getByAltTextSelector(text, options) {
|
40
|
-
return getByAttributeTextSelector('alt', text, options);
|
41
|
-
}
|
42
|
-
function getByTitleSelector(text, options) {
|
43
|
-
return getByAttributeTextSelector('title', text, options);
|
44
|
-
}
|
45
|
-
function getByPlaceholderSelector(text, options) {
|
46
|
-
return getByAttributeTextSelector('placeholder', text, options);
|
47
|
-
}
|
48
|
-
function getByTextSelector(text, options) {
|
49
|
-
return 'internal:text=' + (0, _stringUtils.escapeForTextSelector)(text, !!(options !== null && options !== void 0 && options.exact));
|
50
|
-
}
|
51
|
-
function getByRoleSelector(role, options = {}) {
|
52
|
-
const props = [];
|
53
|
-
if (options.checked !== undefined) props.push(['checked', String(options.checked)]);
|
54
|
-
if (options.disabled !== undefined) props.push(['disabled', String(options.disabled)]);
|
55
|
-
if (options.selected !== undefined) props.push(['selected', String(options.selected)]);
|
56
|
-
if (options.expanded !== undefined) props.push(['expanded', String(options.expanded)]);
|
57
|
-
if (options.includeHidden !== undefined) props.push(['include-hidden', String(options.includeHidden)]);
|
58
|
-
if (options.level !== undefined) props.push(['level', String(options.level)]);
|
59
|
-
if (options.name !== undefined) props.push(['name', (0, _stringUtils.escapeForAttributeSelector)(options.name, !!options.exact)]);
|
60
|
-
if (options.pressed !== undefined) props.push(['pressed', String(options.pressed)]);
|
61
|
-
return `internal:role=${role}${props.map(([n, v]) => `[${n}=${v}]`).join('')}`;
|
62
|
-
}
|
@@ -1,29 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
6
|
-
exports.isJsonMimeType = isJsonMimeType;
|
7
|
-
exports.isTextualMimeType = isTextualMimeType;
|
8
|
-
/**
|
9
|
-
* Copyright (c) Microsoft Corporation.
|
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 isJsonMimeType(mimeType) {
|
25
|
-
return !!mimeType.match(/^(application\/json|application\/.*?\+json|text\/(x-)?json)(;\s*charset=.*)?$/);
|
26
|
-
}
|
27
|
-
function isTextualMimeType(mimeType) {
|
28
|
-
return !!mimeType.match(/^(text\/.*?|application\/(json|(x-)?javascript|xml.*?|ecmascript|graphql|x-www-form-urlencoded)|image\/svg(\+xml)?|application\/.*?(\+json|\+xml))(;\s*charset=.*)?$/);
|
29
|
-
}
|
@@ -1,397 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
6
|
-
Object.defineProperty(exports, "InvalidSelectorError", {
|
7
|
-
enumerable: true,
|
8
|
-
get: function () {
|
9
|
-
return _cssParser.InvalidSelectorError;
|
10
|
-
}
|
11
|
-
});
|
12
|
-
exports.customCSSNames = void 0;
|
13
|
-
Object.defineProperty(exports, "isInvalidSelectorError", {
|
14
|
-
enumerable: true,
|
15
|
-
get: function () {
|
16
|
-
return _cssParser.isInvalidSelectorError;
|
17
|
-
}
|
18
|
-
});
|
19
|
-
exports.parseAttributeSelector = parseAttributeSelector;
|
20
|
-
exports.parseSelector = parseSelector;
|
21
|
-
exports.splitSelectorByFrame = splitSelectorByFrame;
|
22
|
-
exports.stringifySelector = stringifySelector;
|
23
|
-
exports.visitAllSelectorParts = visitAllSelectorParts;
|
24
|
-
var _cssParser = require("./cssParser");
|
25
|
-
/**
|
26
|
-
* Copyright (c) Microsoft Corporation.
|
27
|
-
*
|
28
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
29
|
-
* you may not use this file except in compliance with the License.
|
30
|
-
* You may obtain a copy of the License at
|
31
|
-
*
|
32
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
33
|
-
*
|
34
|
-
* Unless required by applicable law or agreed to in writing, software
|
35
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
36
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
37
|
-
* See the License for the specific language governing permissions and
|
38
|
-
* limitations under the License.
|
39
|
-
*/
|
40
|
-
|
41
|
-
const kNestedSelectorNames = new Set(['internal:has', 'internal:has-not', 'internal:and', 'internal:or', 'internal:chain', 'left-of', 'right-of', 'above', 'below', 'near']);
|
42
|
-
const kNestedSelectorNamesWithDistance = new Set(['left-of', 'right-of', 'above', 'below', 'near']);
|
43
|
-
const customCSSNames = exports.customCSSNames = new Set(['not', 'is', 'where', 'has', 'scope', 'light', 'visible', 'text', 'text-matches', 'text-is', 'has-text', 'above', 'below', 'right-of', 'left-of', 'near', 'nth-match']);
|
44
|
-
function parseSelector(selector) {
|
45
|
-
const parsedStrings = parseSelectorString(selector);
|
46
|
-
const parts = [];
|
47
|
-
for (const part of parsedStrings.parts) {
|
48
|
-
if (part.name === 'css' || part.name === 'css:light') {
|
49
|
-
if (part.name === 'css:light') part.body = ':light(' + part.body + ')';
|
50
|
-
const parsedCSS = (0, _cssParser.parseCSS)(part.body, customCSSNames);
|
51
|
-
parts.push({
|
52
|
-
name: 'css',
|
53
|
-
body: parsedCSS.selector,
|
54
|
-
source: part.body
|
55
|
-
});
|
56
|
-
continue;
|
57
|
-
}
|
58
|
-
if (kNestedSelectorNames.has(part.name)) {
|
59
|
-
let innerSelector;
|
60
|
-
let distance;
|
61
|
-
try {
|
62
|
-
const unescaped = JSON.parse('[' + part.body + ']');
|
63
|
-
if (!Array.isArray(unescaped) || unescaped.length < 1 || unescaped.length > 2 || typeof unescaped[0] !== 'string') throw new _cssParser.InvalidSelectorError(`Malformed selector: ${part.name}=` + part.body);
|
64
|
-
innerSelector = unescaped[0];
|
65
|
-
if (unescaped.length === 2) {
|
66
|
-
if (typeof unescaped[1] !== 'number' || !kNestedSelectorNamesWithDistance.has(part.name)) throw new _cssParser.InvalidSelectorError(`Malformed selector: ${part.name}=` + part.body);
|
67
|
-
distance = unescaped[1];
|
68
|
-
}
|
69
|
-
} catch (e) {
|
70
|
-
throw new _cssParser.InvalidSelectorError(`Malformed selector: ${part.name}=` + part.body);
|
71
|
-
}
|
72
|
-
const nested = {
|
73
|
-
name: part.name,
|
74
|
-
source: part.body,
|
75
|
-
body: {
|
76
|
-
parsed: parseSelector(innerSelector),
|
77
|
-
distance
|
78
|
-
}
|
79
|
-
};
|
80
|
-
const lastFrame = [...nested.body.parsed.parts].reverse().find(part => part.name === 'internal:control' && part.body === 'enter-frame');
|
81
|
-
const lastFrameIndex = lastFrame ? nested.body.parsed.parts.indexOf(lastFrame) : -1;
|
82
|
-
// Allow nested selectors to start with the same frame selector.
|
83
|
-
if (lastFrameIndex !== -1 && selectorPartsEqual(nested.body.parsed.parts.slice(0, lastFrameIndex + 1), parts.slice(0, lastFrameIndex + 1))) nested.body.parsed.parts.splice(0, lastFrameIndex + 1);
|
84
|
-
parts.push(nested);
|
85
|
-
continue;
|
86
|
-
}
|
87
|
-
parts.push({
|
88
|
-
...part,
|
89
|
-
source: part.body
|
90
|
-
});
|
91
|
-
}
|
92
|
-
if (kNestedSelectorNames.has(parts[0].name)) throw new _cssParser.InvalidSelectorError(`"${parts[0].name}" selector cannot be first`);
|
93
|
-
return {
|
94
|
-
capture: parsedStrings.capture,
|
95
|
-
parts
|
96
|
-
};
|
97
|
-
}
|
98
|
-
function splitSelectorByFrame(selectorText) {
|
99
|
-
const selector = parseSelector(selectorText);
|
100
|
-
const result = [];
|
101
|
-
let chunk = {
|
102
|
-
parts: []
|
103
|
-
};
|
104
|
-
let chunkStartIndex = 0;
|
105
|
-
for (let i = 0; i < selector.parts.length; ++i) {
|
106
|
-
const part = selector.parts[i];
|
107
|
-
if (part.name === 'internal:control' && part.body === 'enter-frame') {
|
108
|
-
if (!chunk.parts.length) throw new _cssParser.InvalidSelectorError('Selector cannot start with entering frame, select the iframe first');
|
109
|
-
result.push(chunk);
|
110
|
-
chunk = {
|
111
|
-
parts: []
|
112
|
-
};
|
113
|
-
chunkStartIndex = i + 1;
|
114
|
-
continue;
|
115
|
-
}
|
116
|
-
if (selector.capture === i) chunk.capture = i - chunkStartIndex;
|
117
|
-
chunk.parts.push(part);
|
118
|
-
}
|
119
|
-
if (!chunk.parts.length) throw new _cssParser.InvalidSelectorError(`Selector cannot end with entering frame, while parsing selector ${selectorText}`);
|
120
|
-
result.push(chunk);
|
121
|
-
if (typeof selector.capture === 'number' && typeof result[result.length - 1].capture !== 'number') throw new _cssParser.InvalidSelectorError(`Can not capture the selector before diving into the frame. Only use * after the last frame has been selected`);
|
122
|
-
return result;
|
123
|
-
}
|
124
|
-
function selectorPartsEqual(list1, list2) {
|
125
|
-
return stringifySelector({
|
126
|
-
parts: list1
|
127
|
-
}) === stringifySelector({
|
128
|
-
parts: list2
|
129
|
-
});
|
130
|
-
}
|
131
|
-
function stringifySelector(selector, forceEngineName) {
|
132
|
-
if (typeof selector === 'string') return selector;
|
133
|
-
return selector.parts.map((p, i) => {
|
134
|
-
let includeEngine = true;
|
135
|
-
if (!forceEngineName && i !== selector.capture) {
|
136
|
-
if (p.name === 'css') includeEngine = false;else if (p.name === 'xpath' && p.source.startsWith('//') || p.source.startsWith('..')) includeEngine = false;
|
137
|
-
}
|
138
|
-
const prefix = includeEngine ? p.name + '=' : '';
|
139
|
-
return `${i === selector.capture ? '*' : ''}${prefix}${p.source}`;
|
140
|
-
}).join(' >> ');
|
141
|
-
}
|
142
|
-
function visitAllSelectorParts(selector, visitor) {
|
143
|
-
const visit = (selector, nested) => {
|
144
|
-
for (const part of selector.parts) {
|
145
|
-
visitor(part, nested);
|
146
|
-
if (kNestedSelectorNames.has(part.name)) visit(part.body.parsed, true);
|
147
|
-
}
|
148
|
-
};
|
149
|
-
visit(selector, false);
|
150
|
-
}
|
151
|
-
function parseSelectorString(selector) {
|
152
|
-
let index = 0;
|
153
|
-
let quote;
|
154
|
-
let start = 0;
|
155
|
-
const result = {
|
156
|
-
parts: []
|
157
|
-
};
|
158
|
-
const append = () => {
|
159
|
-
const part = selector.substring(start, index).trim();
|
160
|
-
const eqIndex = part.indexOf('=');
|
161
|
-
let name;
|
162
|
-
let body;
|
163
|
-
if (eqIndex !== -1 && part.substring(0, eqIndex).trim().match(/^[a-zA-Z_0-9-+:*]+$/)) {
|
164
|
-
name = part.substring(0, eqIndex).trim();
|
165
|
-
body = part.substring(eqIndex + 1);
|
166
|
-
} else if (part.length > 1 && part[0] === '"' && part[part.length - 1] === '"') {
|
167
|
-
name = 'text';
|
168
|
-
body = part;
|
169
|
-
} else if (part.length > 1 && part[0] === "'" && part[part.length - 1] === "'") {
|
170
|
-
name = 'text';
|
171
|
-
body = part;
|
172
|
-
} else if (/^\(*\/\//.test(part) || part.startsWith('..')) {
|
173
|
-
// If selector starts with '//' or '//' prefixed with multiple opening
|
174
|
-
// parenthesis, consider xpath. @see https://github.com/microsoft/playwright/issues/817
|
175
|
-
// If selector starts with '..', consider xpath as well.
|
176
|
-
name = 'xpath';
|
177
|
-
body = part;
|
178
|
-
} else {
|
179
|
-
name = 'css';
|
180
|
-
body = part;
|
181
|
-
}
|
182
|
-
let capture = false;
|
183
|
-
if (name[0] === '*') {
|
184
|
-
capture = true;
|
185
|
-
name = name.substring(1);
|
186
|
-
}
|
187
|
-
result.parts.push({
|
188
|
-
name,
|
189
|
-
body
|
190
|
-
});
|
191
|
-
if (capture) {
|
192
|
-
if (result.capture !== undefined) throw new _cssParser.InvalidSelectorError(`Only one of the selectors can capture using * modifier`);
|
193
|
-
result.capture = result.parts.length - 1;
|
194
|
-
}
|
195
|
-
};
|
196
|
-
if (!selector.includes('>>')) {
|
197
|
-
index = selector.length;
|
198
|
-
append();
|
199
|
-
return result;
|
200
|
-
}
|
201
|
-
const shouldIgnoreTextSelectorQuote = () => {
|
202
|
-
const prefix = selector.substring(start, index);
|
203
|
-
const match = prefix.match(/^\s*text\s*=(.*)$/);
|
204
|
-
// Must be a text selector with some text before the quote.
|
205
|
-
return !!match && !!match[1];
|
206
|
-
};
|
207
|
-
while (index < selector.length) {
|
208
|
-
const c = selector[index];
|
209
|
-
if (c === '\\' && index + 1 < selector.length) {
|
210
|
-
index += 2;
|
211
|
-
} else if (c === quote) {
|
212
|
-
quote = undefined;
|
213
|
-
index++;
|
214
|
-
} else if (!quote && (c === '"' || c === '\'' || c === '`') && !shouldIgnoreTextSelectorQuote()) {
|
215
|
-
quote = c;
|
216
|
-
index++;
|
217
|
-
} else if (!quote && c === '>' && selector[index + 1] === '>') {
|
218
|
-
append();
|
219
|
-
index += 2;
|
220
|
-
start = index;
|
221
|
-
} else {
|
222
|
-
index++;
|
223
|
-
}
|
224
|
-
}
|
225
|
-
append();
|
226
|
-
return result;
|
227
|
-
}
|
228
|
-
function parseAttributeSelector(selector, allowUnquotedStrings) {
|
229
|
-
let wp = 0;
|
230
|
-
let EOL = selector.length === 0;
|
231
|
-
const next = () => selector[wp] || '';
|
232
|
-
const eat1 = () => {
|
233
|
-
const result = next();
|
234
|
-
++wp;
|
235
|
-
EOL = wp >= selector.length;
|
236
|
-
return result;
|
237
|
-
};
|
238
|
-
const syntaxError = stage => {
|
239
|
-
if (EOL) throw new _cssParser.InvalidSelectorError(`Unexpected end of selector while parsing selector \`${selector}\``);
|
240
|
-
throw new _cssParser.InvalidSelectorError(`Error while parsing selector \`${selector}\` - unexpected symbol "${next()}" at position ${wp}` + (stage ? ' during ' + stage : ''));
|
241
|
-
};
|
242
|
-
function skipSpaces() {
|
243
|
-
while (!EOL && /\s/.test(next())) eat1();
|
244
|
-
}
|
245
|
-
function isCSSNameChar(char) {
|
246
|
-
// https://www.w3.org/TR/css-syntax-3/#ident-token-diagram
|
247
|
-
return char >= '\u0080' // non-ascii
|
248
|
-
|| char >= '\u0030' && char <= '\u0039' // digit
|
249
|
-
|| char >= '\u0041' && char <= '\u005a' // uppercase letter
|
250
|
-
|| char >= '\u0061' && char <= '\u007a' // lowercase letter
|
251
|
-
|| char >= '\u0030' && char <= '\u0039' // digit
|
252
|
-
|| char === '\u005f' // "_"
|
253
|
-
|| char === '\u002d'; // "-"
|
254
|
-
}
|
255
|
-
function readIdentifier() {
|
256
|
-
let result = '';
|
257
|
-
skipSpaces();
|
258
|
-
while (!EOL && isCSSNameChar(next())) result += eat1();
|
259
|
-
return result;
|
260
|
-
}
|
261
|
-
function readQuotedString(quote) {
|
262
|
-
let result = eat1();
|
263
|
-
if (result !== quote) syntaxError('parsing quoted string');
|
264
|
-
while (!EOL && next() !== quote) {
|
265
|
-
if (next() === '\\') eat1();
|
266
|
-
result += eat1();
|
267
|
-
}
|
268
|
-
if (next() !== quote) syntaxError('parsing quoted string');
|
269
|
-
result += eat1();
|
270
|
-
return result;
|
271
|
-
}
|
272
|
-
function readRegularExpression() {
|
273
|
-
if (eat1() !== '/') syntaxError('parsing regular expression');
|
274
|
-
let source = '';
|
275
|
-
let inClass = false;
|
276
|
-
// https://262.ecma-international.org/11.0/#sec-literals-regular-expression-literals
|
277
|
-
while (!EOL) {
|
278
|
-
if (next() === '\\') {
|
279
|
-
source += eat1();
|
280
|
-
if (EOL) syntaxError('parsing regular expression');
|
281
|
-
} else if (inClass && next() === ']') {
|
282
|
-
inClass = false;
|
283
|
-
} else if (!inClass && next() === '[') {
|
284
|
-
inClass = true;
|
285
|
-
} else if (!inClass && next() === '/') {
|
286
|
-
break;
|
287
|
-
}
|
288
|
-
source += eat1();
|
289
|
-
}
|
290
|
-
if (eat1() !== '/') syntaxError('parsing regular expression');
|
291
|
-
let flags = '';
|
292
|
-
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions
|
293
|
-
while (!EOL && next().match(/[dgimsuy]/)) flags += eat1();
|
294
|
-
try {
|
295
|
-
return new RegExp(source, flags);
|
296
|
-
} catch (e) {
|
297
|
-
throw new _cssParser.InvalidSelectorError(`Error while parsing selector \`${selector}\`: ${e.message}`);
|
298
|
-
}
|
299
|
-
}
|
300
|
-
function readAttributeToken() {
|
301
|
-
let token = '';
|
302
|
-
skipSpaces();
|
303
|
-
if (next() === `'` || next() === `"`) token = readQuotedString(next()).slice(1, -1);else token = readIdentifier();
|
304
|
-
if (!token) syntaxError('parsing property path');
|
305
|
-
return token;
|
306
|
-
}
|
307
|
-
function readOperator() {
|
308
|
-
skipSpaces();
|
309
|
-
let op = '';
|
310
|
-
if (!EOL) op += eat1();
|
311
|
-
if (!EOL && op !== '=') op += eat1();
|
312
|
-
if (!['=', '*=', '^=', '$=', '|=', '~='].includes(op)) syntaxError('parsing operator');
|
313
|
-
return op;
|
314
|
-
}
|
315
|
-
function readAttribute() {
|
316
|
-
// skip leading [
|
317
|
-
eat1();
|
318
|
-
|
319
|
-
// read attribute name:
|
320
|
-
// foo.bar
|
321
|
-
// 'foo' . "ba zz"
|
322
|
-
const jsonPath = [];
|
323
|
-
jsonPath.push(readAttributeToken());
|
324
|
-
skipSpaces();
|
325
|
-
while (next() === '.') {
|
326
|
-
eat1();
|
327
|
-
jsonPath.push(readAttributeToken());
|
328
|
-
skipSpaces();
|
329
|
-
}
|
330
|
-
// check property is truthy: [enabled]
|
331
|
-
if (next() === ']') {
|
332
|
-
eat1();
|
333
|
-
return {
|
334
|
-
name: jsonPath.join('.'),
|
335
|
-
jsonPath,
|
336
|
-
op: '<truthy>',
|
337
|
-
value: null,
|
338
|
-
caseSensitive: false
|
339
|
-
};
|
340
|
-
}
|
341
|
-
const operator = readOperator();
|
342
|
-
let value = undefined;
|
343
|
-
let caseSensitive = true;
|
344
|
-
skipSpaces();
|
345
|
-
if (next() === '/') {
|
346
|
-
if (operator !== '=') throw new _cssParser.InvalidSelectorError(`Error while parsing selector \`${selector}\` - cannot use ${operator} in attribute with regular expression`);
|
347
|
-
value = readRegularExpression();
|
348
|
-
} else if (next() === `'` || next() === `"`) {
|
349
|
-
value = readQuotedString(next()).slice(1, -1);
|
350
|
-
skipSpaces();
|
351
|
-
if (next() === 'i' || next() === 'I') {
|
352
|
-
caseSensitive = false;
|
353
|
-
eat1();
|
354
|
-
} else if (next() === 's' || next() === 'S') {
|
355
|
-
caseSensitive = true;
|
356
|
-
eat1();
|
357
|
-
}
|
358
|
-
} else {
|
359
|
-
value = '';
|
360
|
-
while (!EOL && (isCSSNameChar(next()) || next() === '+' || next() === '.')) value += eat1();
|
361
|
-
if (value === 'true') {
|
362
|
-
value = true;
|
363
|
-
} else if (value === 'false') {
|
364
|
-
value = false;
|
365
|
-
} else {
|
366
|
-
if (!allowUnquotedStrings) {
|
367
|
-
value = +value;
|
368
|
-
if (Number.isNaN(value)) syntaxError('parsing attribute value');
|
369
|
-
}
|
370
|
-
}
|
371
|
-
}
|
372
|
-
skipSpaces();
|
373
|
-
if (next() !== ']') syntaxError('parsing attribute value');
|
374
|
-
eat1();
|
375
|
-
if (operator !== '=' && typeof value !== 'string') throw new _cssParser.InvalidSelectorError(`Error while parsing selector \`${selector}\` - cannot use ${operator} in attribute with non-string matching value - ${value}`);
|
376
|
-
return {
|
377
|
-
name: jsonPath.join('.'),
|
378
|
-
jsonPath,
|
379
|
-
op: operator,
|
380
|
-
value,
|
381
|
-
caseSensitive
|
382
|
-
};
|
383
|
-
}
|
384
|
-
const result = {
|
385
|
-
name: '',
|
386
|
-
attributes: []
|
387
|
-
};
|
388
|
-
result.name = readIdentifier();
|
389
|
-
skipSpaces();
|
390
|
-
while (next() === '[') {
|
391
|
-
result.attributes.push(readAttribute());
|
392
|
-
skipSpaces();
|
393
|
-
}
|
394
|
-
if (!EOL) syntaxError(undefined);
|
395
|
-
if (!result.name && !result.attributes.length) throw new _cssParser.InvalidSelectorError(`Error while parsing selector \`${selector}\` - selector cannot be empty`);
|
396
|
-
return result;
|
397
|
-
}
|