From ef79d3da0455c510f334041b29909c32b04770be Mon Sep 17 00:00:00 2001 From: Daniel Moran Date: Mon, 8 Feb 2021 17:42:59 -0500 Subject: [PATCH] build: clean up e2e code (#20728) --- .circleci/config.yml | 19 - e2e/.babelrc | 12 - e2e/.eslintrc.json | 39 - e2e/Makefile | 35 - e2e/README.md | 259 ---- .../features/signin/01_signinPerf.feature | 24 - .../features/signin/02_signinCloud.feature | 20 - e2e/cucumber.js | 108 -- e2e/e2e.conf.json | 80 -- e2e/etc/selenoid/config/browsers.json | 48 - e2e/etc/test-data/alpha_dashboard.json | 282 ----- e2e/etc/test-data/bad-template.json | 1 - e2e/etc/test-data/hydro-test-template.json | 176 --- e2e/etc/test-data/line-protocol-bogus.txt | 1 - e2e/etc/test-data/note-dboard-template.json | 68 - e2e/etc/test-data/notepad-test-template.json | 100 -- e2e/etc/test-data/sine-test-template.json | 174 --- e2e/etc/test-data/tau_ceti_dashboard.json | 282 ----- .../test-data/test_deadman_crit_check.json | 30 - e2e/etc/test-data/test_threshold_check.json | 36 - e2e/etc/test-data/variable-csv-arsenal.json | 44 - e2e/etc/test-data/variable-csv-slavia.json | 44 - e2e/etc/test-data/variable-empty.json | 1 - .../test-data/variable-map-jehlicnany.json | 39 - e2e/etc/test-data/variable-map-ryby.json | 37 - e2e/etc/test-data/variable-query-bucket.json | 34 - e2e/features/dashboards/cellEdit.feature | 694 ----------- e2e/features/dashboards/dashboard.feature | 350 ------ e2e/features/dashboards/dashboards.feature | 309 ----- e2e/features/dashboards/noteCell.feature | 91 -- e2e/features/dashboards/variables.feature | 344 ------ .../dataExplorer/dataExplorer.feature | 176 --- e2e/features/homePage/homePage.feature | 50 - e2e/features/influx/influx.feature | 99 -- e2e/features/loadData/buckets.feature | 276 ----- e2e/features/loadData/clientlib.feature | 52 - e2e/features/loadData/loadData.feature | 21 - e2e/features/loadData/scrapers.feature | 156 --- e2e/features/loadData/telegrafs.feature | 226 ---- e2e/features/loadData/tokens.feature | 183 --- e2e/features/monitoring/alerts.feature | 527 -------- e2e/features/monitoring/history.feature | 59 - e2e/features/onboarding/onboarding.feature | 84 -- e2e/features/settings/labels.feature | 152 --- e2e/features/settings/settings.feature | 27 - e2e/features/settings/templates.feature | 168 --- e2e/features/settings/variables.feature | 349 ------ e2e/features/signin/signin.feature | 36 - e2e/hooks.js | 156 --- e2e/package.json | 42 - e2e/scripts/Dockerfile | 3 - e2e/scripts/Dockerfile.cloud | 15 - e2e/scripts/Dockerfile.e2e | 18 - e2e/scripts/Dockerfile.tests | 14 - e2e/scripts/circleci-run.sh | 33 - e2e/scripts/cloud-test.sh | 6 - e2e/scripts/containerTests.sh | 140 --- e2e/scripts/influxdb2_community_test_env.sh | 200 --- e2e/scripts/selenoid.sh | 25 - e2e/src/pages/basePage.js | 394 ------ e2e/src/pages/cloud/cloudLoginPage.js | 55 - e2e/src/pages/createOrgPage.js | 51 - e2e/src/pages/dashboards/cellEditOverlay.js | 533 -------- e2e/src/pages/dashboards/dashboardPage.js | 321 ----- e2e/src/pages/dashboards/dashboardsPage.js | 332 ----- .../pages/dataExplorer/dataExplorerPage.js | 301 ----- e2e/src/pages/home/homePage.js | 88 -- e2e/src/pages/influxPage.js | 167 --- e2e/src/pages/loadData/bucketsTab.js | 339 ----- e2e/src/pages/loadData/clientLibsTab.js | 43 - e2e/src/pages/loadData/loadDataPage.js | 146 --- e2e/src/pages/loadData/scrapersTab.js | 93 -- e2e/src/pages/loadData/telegrafsTab.js | 317 ----- e2e/src/pages/loadData/tokensTab.js | 196 --- e2e/src/pages/monitoring/alertsPage.js | 266 ---- e2e/src/pages/monitoring/checkEditPage.js | 198 --- .../monitoring/checkStatusHistoryPage.js | 124 -- e2e/src/pages/onboarding/initialSetupPage.js | 58 - e2e/src/pages/onboarding/readyPage.js | 39 - e2e/src/pages/onboarding/splashPage.js | 30 - .../pages/organization/organizationPage.js | 35 - e2e/src/pages/settings/labelsTab.js | 140 --- e2e/src/pages/settings/membersTab.js | 25 - e2e/src/pages/settings/orgProfileTab.js | 27 - e2e/src/pages/settings/settingsPage.js | 33 - e2e/src/pages/settings/templatesTab.js | 115 -- e2e/src/pages/settings/variablesTab.js | 250 ---- e2e/src/pages/signin/signinPage.js | 51 - e2e/src/pages/tasks/tasksPage.js | 77 -- .../step_definitions/common/cloudStepDefs.js | 42 - .../step_definitions/common/commonStepDefs.js | 414 ------- .../dashboards/cellOverlayStepDefs.js | 598 --------- .../dashboards/dashboardStepDefs.js | 339 ----- .../dashboards/dashboardsStepDefs.js | 288 ----- .../dataExplorer/dataExplorerStepDefs.js | 204 --- e2e/src/step_definitions/home/homeStepDefs.js | 35 - .../step_definitions/influx/influxStepDefs.js | 62 - .../loadData/bucketsStepDefs.js | 316 ----- .../loadData/clientLibStepDefs.js | 45 - .../loadData/loadDataStepDefs.js | 108 -- .../loadData/scrapersStepDefs.js | 97 -- .../loadData/telegrafStepDefs.js | 299 ----- .../loadData/tokensStepDefs.js | 221 ---- .../monitoring/checkEditStepDefs.js | 230 ---- .../monitoring/checkStatusHistoryStepDefs.js | 73 -- .../monitoring/monitoringStepDefs.js | 208 ---- .../onboarding/onboardStepDefs.js | 145 --- .../organization/organizationStepDefs.js | 13 - .../settings/labelsStepDefs.js | 150 --- .../settings/settingsStepDefs.js | 51 - .../settings/templatesStepDefs.js | 112 -- .../settings/variablesStepDefs.js | 298 ----- .../step_definitions/signin/signinStepDefs.js | 42 - .../step_definitions/tasks/tasksStepDefs.js | 14 - e2e/src/steps/baseSteps.js | 862 ------------- e2e/src/steps/cloudSteps.js | 106 -- e2e/src/steps/createOrgSteps.js | 25 - e2e/src/steps/dashboards/cellOverlaySteps.js | 1098 ----------------- e2e/src/steps/dashboards/dashboardSteps.js | 675 ---------- e2e/src/steps/dashboards/dashboardsSteps.js | 371 ------ .../steps/dataExplorer/dataExplorerSteps.js | 471 ------- e2e/src/steps/home/homeSteps.js | 79 -- e2e/src/steps/influx/influxSteps.js | 173 --- e2e/src/steps/loadData/bucketsSteps.js | 683 ---------- e2e/src/steps/loadData/clientLibsSteps.js | 84 -- e2e/src/steps/loadData/loadDataSteps.js | 200 --- e2e/src/steps/loadData/scrapersSteps.js | 211 ---- e2e/src/steps/loadData/telegrafsSteps.js | 500 -------- e2e/src/steps/loadData/tokensSteps.js | 323 ----- e2e/src/steps/monitoring/checkEditSteps.js | 308 ----- .../monitoring/checkStatusHistorySteps.js | 198 --- e2e/src/steps/monitoring/monitoringSteps.js | 254 ---- e2e/src/steps/onboarding/onboardingSteps.js | 147 --- .../steps/organization/organizationSteps.js | 29 - e2e/src/steps/settings/labelsSteps.js | 244 ---- e2e/src/steps/settings/membersSteps.js | 17 - e2e/src/steps/settings/orgProfileSteps.js | 17 - e2e/src/steps/settings/settingsSteps.js | 36 - e2e/src/steps/settings/templatesSteps.js | 145 --- e2e/src/steps/settings/variablesSteps.js | 348 ------ e2e/src/steps/signin/signinSteps.js | 119 -- e2e/src/steps/tasks/tasksSteps.js | 33 - e2e/src/utils/htmlReport.js | 20 - e2e/src/utils/influxUtils.js | 982 --------------- e2e/src/utils/junitReport.js | 9 - e2e/src/utils/performanceUtils.js | 149 --- 146 files changed, 25238 deletions(-) delete mode 100644 e2e/.babelrc delete mode 100644 e2e/.eslintrc.json delete mode 100644 e2e/Makefile delete mode 100644 e2e/README.md delete mode 100644 e2e/cloud/features/signin/01_signinPerf.feature delete mode 100644 e2e/cloud/features/signin/02_signinCloud.feature delete mode 100644 e2e/cucumber.js delete mode 100644 e2e/e2e.conf.json delete mode 100644 e2e/etc/selenoid/config/browsers.json delete mode 100644 e2e/etc/test-data/alpha_dashboard.json delete mode 100644 e2e/etc/test-data/bad-template.json delete mode 100644 e2e/etc/test-data/hydro-test-template.json delete mode 100644 e2e/etc/test-data/line-protocol-bogus.txt delete mode 100644 e2e/etc/test-data/note-dboard-template.json delete mode 100644 e2e/etc/test-data/notepad-test-template.json delete mode 100644 e2e/etc/test-data/sine-test-template.json delete mode 100644 e2e/etc/test-data/tau_ceti_dashboard.json delete mode 100644 e2e/etc/test-data/test_deadman_crit_check.json delete mode 100644 e2e/etc/test-data/test_threshold_check.json delete mode 100644 e2e/etc/test-data/variable-csv-arsenal.json delete mode 100644 e2e/etc/test-data/variable-csv-slavia.json delete mode 100644 e2e/etc/test-data/variable-empty.json delete mode 100644 e2e/etc/test-data/variable-map-jehlicnany.json delete mode 100644 e2e/etc/test-data/variable-map-ryby.json delete mode 100644 e2e/etc/test-data/variable-query-bucket.json delete mode 100644 e2e/features/dashboards/cellEdit.feature delete mode 100644 e2e/features/dashboards/dashboard.feature delete mode 100644 e2e/features/dashboards/dashboards.feature delete mode 100644 e2e/features/dashboards/noteCell.feature delete mode 100644 e2e/features/dashboards/variables.feature delete mode 100644 e2e/features/dataExplorer/dataExplorer.feature delete mode 100644 e2e/features/homePage/homePage.feature delete mode 100644 e2e/features/influx/influx.feature delete mode 100644 e2e/features/loadData/buckets.feature delete mode 100644 e2e/features/loadData/clientlib.feature delete mode 100644 e2e/features/loadData/loadData.feature delete mode 100644 e2e/features/loadData/scrapers.feature delete mode 100644 e2e/features/loadData/telegrafs.feature delete mode 100644 e2e/features/loadData/tokens.feature delete mode 100644 e2e/features/monitoring/alerts.feature delete mode 100644 e2e/features/monitoring/history.feature delete mode 100644 e2e/features/onboarding/onboarding.feature delete mode 100644 e2e/features/settings/labels.feature delete mode 100644 e2e/features/settings/settings.feature delete mode 100644 e2e/features/settings/templates.feature delete mode 100644 e2e/features/settings/variables.feature delete mode 100644 e2e/features/signin/signin.feature delete mode 100644 e2e/hooks.js delete mode 100644 e2e/package.json delete mode 100644 e2e/scripts/Dockerfile delete mode 100644 e2e/scripts/Dockerfile.cloud delete mode 100644 e2e/scripts/Dockerfile.e2e delete mode 100644 e2e/scripts/Dockerfile.tests delete mode 100755 e2e/scripts/circleci-run.sh delete mode 100755 e2e/scripts/cloud-test.sh delete mode 100755 e2e/scripts/containerTests.sh delete mode 100755 e2e/scripts/influxdb2_community_test_env.sh delete mode 100755 e2e/scripts/selenoid.sh delete mode 100644 e2e/src/pages/basePage.js delete mode 100644 e2e/src/pages/cloud/cloudLoginPage.js delete mode 100644 e2e/src/pages/createOrgPage.js delete mode 100644 e2e/src/pages/dashboards/cellEditOverlay.js delete mode 100644 e2e/src/pages/dashboards/dashboardPage.js delete mode 100644 e2e/src/pages/dashboards/dashboardsPage.js delete mode 100644 e2e/src/pages/dataExplorer/dataExplorerPage.js delete mode 100644 e2e/src/pages/home/homePage.js delete mode 100644 e2e/src/pages/influxPage.js delete mode 100644 e2e/src/pages/loadData/bucketsTab.js delete mode 100644 e2e/src/pages/loadData/clientLibsTab.js delete mode 100644 e2e/src/pages/loadData/loadDataPage.js delete mode 100644 e2e/src/pages/loadData/scrapersTab.js delete mode 100644 e2e/src/pages/loadData/telegrafsTab.js delete mode 100644 e2e/src/pages/loadData/tokensTab.js delete mode 100644 e2e/src/pages/monitoring/alertsPage.js delete mode 100644 e2e/src/pages/monitoring/checkEditPage.js delete mode 100644 e2e/src/pages/monitoring/checkStatusHistoryPage.js delete mode 100644 e2e/src/pages/onboarding/initialSetupPage.js delete mode 100644 e2e/src/pages/onboarding/readyPage.js delete mode 100644 e2e/src/pages/onboarding/splashPage.js delete mode 100644 e2e/src/pages/organization/organizationPage.js delete mode 100644 e2e/src/pages/settings/labelsTab.js delete mode 100644 e2e/src/pages/settings/membersTab.js delete mode 100644 e2e/src/pages/settings/orgProfileTab.js delete mode 100644 e2e/src/pages/settings/settingsPage.js delete mode 100644 e2e/src/pages/settings/templatesTab.js delete mode 100644 e2e/src/pages/settings/variablesTab.js delete mode 100644 e2e/src/pages/signin/signinPage.js delete mode 100644 e2e/src/pages/tasks/tasksPage.js delete mode 100644 e2e/src/step_definitions/common/cloudStepDefs.js delete mode 100644 e2e/src/step_definitions/common/commonStepDefs.js delete mode 100644 e2e/src/step_definitions/dashboards/cellOverlayStepDefs.js delete mode 100644 e2e/src/step_definitions/dashboards/dashboardStepDefs.js delete mode 100644 e2e/src/step_definitions/dashboards/dashboardsStepDefs.js delete mode 100644 e2e/src/step_definitions/dataExplorer/dataExplorerStepDefs.js delete mode 100644 e2e/src/step_definitions/home/homeStepDefs.js delete mode 100644 e2e/src/step_definitions/influx/influxStepDefs.js delete mode 100644 e2e/src/step_definitions/loadData/bucketsStepDefs.js delete mode 100644 e2e/src/step_definitions/loadData/clientLibStepDefs.js delete mode 100644 e2e/src/step_definitions/loadData/loadDataStepDefs.js delete mode 100644 e2e/src/step_definitions/loadData/scrapersStepDefs.js delete mode 100644 e2e/src/step_definitions/loadData/telegrafStepDefs.js delete mode 100644 e2e/src/step_definitions/loadData/tokensStepDefs.js delete mode 100644 e2e/src/step_definitions/monitoring/checkEditStepDefs.js delete mode 100644 e2e/src/step_definitions/monitoring/checkStatusHistoryStepDefs.js delete mode 100644 e2e/src/step_definitions/monitoring/monitoringStepDefs.js delete mode 100644 e2e/src/step_definitions/onboarding/onboardStepDefs.js delete mode 100644 e2e/src/step_definitions/organization/organizationStepDefs.js delete mode 100644 e2e/src/step_definitions/settings/labelsStepDefs.js delete mode 100644 e2e/src/step_definitions/settings/settingsStepDefs.js delete mode 100644 e2e/src/step_definitions/settings/templatesStepDefs.js delete mode 100644 e2e/src/step_definitions/settings/variablesStepDefs.js delete mode 100644 e2e/src/step_definitions/signin/signinStepDefs.js delete mode 100644 e2e/src/step_definitions/tasks/tasksStepDefs.js delete mode 100644 e2e/src/steps/baseSteps.js delete mode 100644 e2e/src/steps/cloudSteps.js delete mode 100644 e2e/src/steps/createOrgSteps.js delete mode 100644 e2e/src/steps/dashboards/cellOverlaySteps.js delete mode 100644 e2e/src/steps/dashboards/dashboardSteps.js delete mode 100644 e2e/src/steps/dashboards/dashboardsSteps.js delete mode 100644 e2e/src/steps/dataExplorer/dataExplorerSteps.js delete mode 100644 e2e/src/steps/home/homeSteps.js delete mode 100644 e2e/src/steps/influx/influxSteps.js delete mode 100644 e2e/src/steps/loadData/bucketsSteps.js delete mode 100644 e2e/src/steps/loadData/clientLibsSteps.js delete mode 100644 e2e/src/steps/loadData/loadDataSteps.js delete mode 100644 e2e/src/steps/loadData/scrapersSteps.js delete mode 100644 e2e/src/steps/loadData/telegrafsSteps.js delete mode 100644 e2e/src/steps/loadData/tokensSteps.js delete mode 100644 e2e/src/steps/monitoring/checkEditSteps.js delete mode 100644 e2e/src/steps/monitoring/checkStatusHistorySteps.js delete mode 100644 e2e/src/steps/monitoring/monitoringSteps.js delete mode 100644 e2e/src/steps/onboarding/onboardingSteps.js delete mode 100644 e2e/src/steps/organization/organizationSteps.js delete mode 100644 e2e/src/steps/settings/labelsSteps.js delete mode 100644 e2e/src/steps/settings/membersSteps.js delete mode 100644 e2e/src/steps/settings/orgProfileSteps.js delete mode 100644 e2e/src/steps/settings/settingsSteps.js delete mode 100644 e2e/src/steps/settings/templatesSteps.js delete mode 100644 e2e/src/steps/settings/variablesSteps.js delete mode 100644 e2e/src/steps/signin/signinSteps.js delete mode 100644 e2e/src/steps/tasks/tasksSteps.js delete mode 100755 e2e/src/utils/htmlReport.js delete mode 100644 e2e/src/utils/influxUtils.js delete mode 100755 e2e/src/utils/junitReport.js delete mode 100644 e2e/src/utils/performanceUtils.js diff --git a/.circleci/config.yml b/.circleci/config.yml index 5df70e7e33..65fb09f4fe 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -56,25 +56,6 @@ workflows: branches: only: master - hourly-e2e: - triggers: - - schedule: - cron: "0 * * * *" - filters: - branches: - only: - - master - jobs: - - godeps - - jsdeps - - build: - requires: - - godeps - - jsdeps - - e2e: - requires: - - build - nightly: triggers: - schedule: diff --git a/e2e/.babelrc b/e2e/.babelrc deleted file mode 100644 index 0c2b576eec..0000000000 --- a/e2e/.babelrc +++ /dev/null @@ -1,12 +0,0 @@ -{ - "presets": [ - [ - "env", - { - "targets": { - "node": "current" - } - } - ] - ] -} diff --git a/e2e/.eslintrc.json b/e2e/.eslintrc.json deleted file mode 100644 index 93b30f88b6..0000000000 --- a/e2e/.eslintrc.json +++ /dev/null @@ -1,39 +0,0 @@ -{ - "env": { - "es6": true, - "node": true - }, - "extends": "eslint:recommended", - "globals": { - "Atomics": "readonly", - "SharedArrayBuffer": "readonly", - "__srcdir" : "readonly", - "__basedir" : "readonly", - "__wdriver" : "readonly", - "__defaultUser": "readonly", - "__config": "readonly", - "__users": "writable" - }, - "parserOptions": { - "ecmaVersion": 2018, - "sourceType": "module" - }, - "rules": { - "indent": [ - "error", - 4 - ], - "linebreak-style": [ - "error", - "unix" - ], - "quotes": [ - "error", - "single" - ], - "semi": [ - "error", - "always" - ] - } -} diff --git a/e2e/Makefile b/e2e/Makefile deleted file mode 100644 index 7ea930cd51..0000000000 --- a/e2e/Makefile +++ /dev/null @@ -1,35 +0,0 @@ -.PHONY: docker-build docker-prep docker-test docker-test-kill docker-report test clean - -RUNCMD ?= cucumber-js --tags 'not @tested and not @error-collateral' - -docker-build: - docker build -t e2e-tests -f scripts/Dockerfile.e2e . - -docker-prep: - mkdir -p /tmp/report \ - && docker pull quay.io/influxdb/influx:nightly - docker run -d --rm --name=test-influxdb quay.io/influxdb/influx:nightly influxd --e2e-testing=true \ - && sleep 30s - -docker-test: docker-build - docker run --rm --name=test-e2e -v /tmp/report:/selenium-accept-infl2/report --network=container:test-influxdb e2e-tests ${RUNCMD} - -docker-report: - docker run --rm -t --name=test-e2e -v /tmp/report:/selenium-accept-infl2/report e2e-tests npm run report:html - -docker-test-kill: - docker rm -f test-e2e - -test: docker-test docker-report - -clean: - docker rm -f test-influxdb - rm -rf /tmp/report - -bonitoo-prep: - npm run influx:setup - -bonitoo-docker: - ./scripts/containerTests.sh - -bonitoo-test: bonitoo-prep bonitoo-docker diff --git a/e2e/README.md b/e2e/README.md deleted file mode 100644 index 87a8987c91..0000000000 --- a/e2e/README.md +++ /dev/null @@ -1,259 +0,0 @@ -## Selenium-Accept - -Selenium Acceptance tests for the Influxdbv2 UI. These tests were initially intended to support nightly testing of the open source (OSS) poduct. They are currently (7. 2020) being leveraged to support synthetic testing of the cloud deployments. This leveraging has lead to some substantial changes and improvements in configuration. - -**Run cycle** - -*original OSS* - -```bash -npm install -npm run influx:setup -npm test -node src/utils/htmlReport.js -node src/utils/junitReport.js -``` - -Note that the final two reporting steps can be bundled into `package.json` scripts, or can be called as a part of the `package.json` *test* script. They are shown here to show how third party components are used to generate reports. - -To clean the reports and screenshots directories: - -```bash -npm run clean -``` - -### Configuration - -Tests are configured in the file `e2e.conf.json`. The configuration to be used for a test run is specified -by the property `active` in this file. This can be overridden on the commandline. - -**Command Line Arguments** - -The following command line arguments are detected at load time. - - * `headless` - boolean. Whether to run the tests headless or not. - * `sel_docker` or `selDocker` - boolean. Added for influxdata docker tests. Chooses options needed for running tests in the influxdata docker container. - * `active_conf` or `activeConf` - string. Declare the configuration to be activated for the test run. Must match a config declared in `e2e.conf.json`. - -For example to run the dataexplorer feature `headless` against the `nightly` build configuration: - -```bash -npm test headless=true activeConf=nightly -- features/dataExplorer/dataExplorer.feature -``` - -Another example to test the signin feature using _tags_, `headless` and against the `nighty` configuration. - -```bash -npm test -- headless=true activeConf=nightly -t "@feature-signin" -``` - -**Environment Variable Overrides** - -Configuration properties can be overridden by `E2E` environment variables. The basic pattern for exporting an environment variable to be picked up for test configuration is the token `E2E` followed by an underscore, then the path to the property to be modified as defined by the configuration tree in `e2e.conf.json`. Each node in the tree is declared in uppercase and separated by an underscore. - -For example, to declare the `influx_url` property in the `development` configuration export the environment variable `E2E_DEVELOPMENT_INFLUX_URL`. - -e.g. - -`export E2E_DEVELOPMENT_INFLUX_URL="http://172.17.0.2:8086"` - -This feature was added specifically to define passwords and usernames only via the test environment. However, it can be used with any configuration key value such as the INFLUX_URL endpoint. - -e.g. - -```bash -export E2E_NIGHTLY_DEFAULT_USER_USERNAME=hibou -export E2E_NIGHTLY_DEFAULT_USER_PASSWORD=HuluHulu -``` - -**Note** - if password or token values in the configuration file are declared with the value _"ENV"_ then they must be defined by an environment variable as shown above. Failure to define the values in the environment will lead to 400 bad request and similar errors, for example when creating users at the start of a test feature. - -**User Generation** - -In the configration file the key `create_method` defines the method to be used to create the user and associated artifacts. Four values for this key are recognized. - - * `REST` - use the rest endpoint to create the user directly. Recommended. - * `CLI` - use the command line client to create the user. Experimental. **_CAUTION_** Deletes the file `${USER_HOME}/.influxdbv2/configs` and regenerates it. Depends on additional special configuration keys: - * `influx_path` - path to the `influx` client executable, used to create the user. - * `CLI_DOCKER` - use the command line client inside the docker container. Experimental. Depends on additional special configuration keys: - * `docker_name` - name of the docker container in which influxdbv2 is running. - * `SKIP` - skip user creation. It is assumed the user account will already exist in the deployment under test. - -Note that in the Containerized version described below, the `CLI` and `CLI_DOCKER` user generation modes do not currently (7.2020) work. - -### Containerized test runs against Selenoid - -In June 2020 scripts were prepared to containerize the tests using a standard node version 12 container from docker and Selenoid browser containers. This approach should make it easier to port the test infrastructure into other CI pipelines as well as to expand browser coverage. - -The entire process is defined in the script `./scripts/containerTests.sh`. - -This script does the following: - - 1. Stops and tears down any existing docker container containing these tests. - 1. Stops and tears down any running Selenoid containers. - 1. Restarts Selenoid via the script `./scripts/selenoid.sh`. - 1. Rebuilds the docker image containing these tests. Note this is currently (7.2020) based on the standard docker nodejs v 12.16 image and uses `./scripts/Dokcerfile.tests`. - 1. Executes the tests based on tag definitions passed to the script using the argument `-t` or `--tags` (defaults to "@influx-influx") and using the configuration passed through the optional argument `-c` or `--config` (defaults to "development"). - -Examples - -```bash -$ scripts/containerTests.sh --tags "not @download-file" -$ scripts/containerTests.sh --tags "@feature-signin" -``` - -**Mapping directories between containers** - -Note that this script maps the `etc` directory containing test data and upload files by linking it to the system `/tmp` directory and then mapping that volume into the docker containers. This solution will not work when selenoid and test containers are not hosted on the same machine. - -**Debugging Selenoid** - -Debugging Selenoid tests entails starting the `selenoid-ui` container and then accessing it at `http://localhost:8080/#/`. - -```bash -scripts/selenoid.sh -debug -``` - -_Do not_ run the `containerTests.sh` script. Instead start the test as it is started in that script. - -e.g. -```bash -sudo docker run -it -v `pwd`/report:/home/e2e/report -v `pwd`/screenshots:/home/e2e/screenshots \ - -v /tmp/e2e/etc:/home/e2e/etc -v /tmp/e2e/downloads:/home/e2e/downloads \ - -e SELENIUM_REMOTE_URL="http://${SELENOID_HOST}:4444/wd/hub" \ - -e E2E_${ACTIVE_CONF^^}_INFLUX_URL="http://${INFLUX2_HOST}:8086" --detach \ - --name ${TEST_CONTAINER} e2e-${TEST_CONTAINER}:latest -``` - -Then run tests against it. - -```bash -sudo docker exec ${TEST_CONTAINER} npm test -- activeConf=${ACTIVE_CONF} --tags "$TAGS" -``` - -Test runs can then be monitored through the Selenoid UI. Open the active session and log and VNC windows will open. - -**Video with Selenoid** - -It is also possible to record an MP4 of a debug test run. In the script `selenoid.sh` uncomment the following line: - -```bash -sudo docker pull selenoid/video-recorder:latest-release -``` - -And for now, in `cucumber.js` uncomment the line: - -```javascript -caps.set('enableVideo', true); -``` - -Then rerun the script `selenoid.sh` with the argument `-debug`. - -### Light Weight Performance checks - -For tests against the cloud a light weigh performance utility has been added. It currently exports only one method for tests: `execTimed( func, maxDelay, failMsg, successMsg)`. This method will execute the passed function and expect it to resolve by `maxDelay` milliseconds. Failures are thrown to cucumber and results are stored in a performance log buffer. This log is then dumped to the console after all tests have been run. They are also written to a CSV report file: `./report/performance.csv`. - -For example, here is how it is used to check the redirect to the login page. - -```javascript - async openCloudPage(maxDelay){ - await perfUtils.execTimed(async () => { - await this.driver.get(__config.influx_url); - await this.loginPage.waitToLoad(10000); - }, - maxDelay, `Redirect failed to resolve in ${maxDelay} ms`); - } - -``` - -### Tips - -Run only the feature under development - -```bash -npm test -- features/onboarding/onboarding.feature:4 -``` - -Number is line number where the target scenario starts. To run the whole featre it can be omitted. - -Run the same headless - -```bash -npm test headless=true -- features/onboarding/onboarding.feature:4 -``` - -### API Notes - -Steps classes should directly or indirectly inherit from the `baseSteps` class in `baseSteps.js`. This class contains some generic methods to streamline Selenium and Cucumber interactions. More will be added as the test suite grows. Here is a list as of 1.10.2019. - -`assertNotPresent(selector)` - -`assertNotVisible(element)` - -`assertVisible(element)` - -`clearInputText(input)` - -`clickAndWait(element, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); })` - -`clickPopupWizardContinue()` - -`clickPopupWizardPrevious()` - -`clickPopupWizardFinish()` - -`clickPopupCancelBtn()` - -`closeAllNotifications()` - -`containsNotificationText(text)` - -`containsErrorNotification(text)` - -`delay(timeout)` - -`dismissPopup()` - -`hoverOver(element)` - -`typeTextAndWait(input, text, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); })` - -`verifyElementContainsText(element, text)` - -`verifyElementContainsClass(element, clazz)` - -`verifyElementDoesNotContainClass(element, clazz)` - -`verifyElementDisabled(element)` - -`verifyElementErrorMessage(msg, equal = true)` - -`verifyElementText(element, text)` - -`verifyInputErrorIcon()` - -`verifyInputEqualsValue(input, value)` - -`verifyInputContainsValue(input, value)` - -`verifyInputDoesNotContainValue(input, value)` - -`verifyNoElementErrorMessage()` - -`verifyNoFormInputErrorIcon()` - -`verifyPopupAlertContainsText(text)` - -`verifyPopupAlertMatchesRegex(regex)` - -`verifyPopupNotPresent()` - -`verifyWizardContinueButtonDisabled()` - -`verifyWizardDocsLinkURL(url)` - -Pages should inherit directly or indirectly from the `basePage` class in `basePage.js`. This contains many common selectors and element getters found either in the over all framework or in common components such as wizards and popups. - -The file `commonStepDefs.js` contains a library of test statements leveraging `baseSteps` and covering functionality that will often need to be repeated. It also contains steps for accessing methods from `influxUtils.js` for accessing the REST api through AXIOS, which is useful for setting up test data for a feature set. diff --git a/e2e/cloud/features/signin/01_signinPerf.feature b/e2e/cloud/features/signin/01_signinPerf.feature deleted file mode 100644 index 3935d04921..0000000000 --- a/e2e/cloud/features/signin/01_signinPerf.feature +++ /dev/null @@ -1,24 +0,0 @@ -Feature: Cloud Signin - Perf - Check basic loading times of cloud login - - @perf-test - @cloud-test - Scenario: Perf - redirect to login - When open the cloud page in "3000" milliseconds - - @perf-test - @cloud-test - Scenario: Perf: login to home - When I open the cloud login - When log in to the cloud in "3000" milliseconds - - @perf-test - @cloud-test - Scenario: Perf - logout to account - # N.B. on free account first logout should load account info - When I logout to account info in "3000" milliseconds - - @perf-test - @cloud-test - Scenario: Perf - logout to login - When I logout to login page in "3000" milliseconds diff --git a/e2e/cloud/features/signin/02_signinCloud.feature b/e2e/cloud/features/signin/02_signinCloud.feature deleted file mode 100644 index cd6ff96a31..0000000000 --- a/e2e/cloud/features/signin/02_signinCloud.feature +++ /dev/null @@ -1,20 +0,0 @@ -Feature: Cloud Signin - Func - Use and abuse the cloud signin page - -@cloud-test -Scenario: login to cloud password - When I open the cloud login - When log in to the cloud - Then the home page is loaded - -@cloud-test -Scenario: logout influx menu - When click nav menu item "User" - When click user nav item "Logout" - # Need second click - 1st should lead to account info - # TODO update when account info page loads - issue #19057 - When click nav menu item "User" - When click user nav item "Logout" - Then the cloud login page is loaded - -#Scenario: excersize login page diff --git a/e2e/cucumber.js b/e2e/cucumber.js deleted file mode 100644 index b88e057b68..0000000000 --- a/e2e/cucumber.js +++ /dev/null @@ -1,108 +0,0 @@ -const chrome = require('selenium-webdriver/chrome'); -const ffox = require('selenium-webdriver/firefox'); -const fs = require('fs'); -const {Builder, Capabilities, By, Key, LocalFileDetector, logging, PageLoadStrategy, promise, until} = require('selenium-webdriver'); -//following provides cleaner paths in require statements -global.__basedir = __dirname; -global.__srcdir = __dirname + "/src"; -global.__runtime = new Date(); -global.__runtimeStr = __runtime.getFullYear().toString() + - (__runtime.getMonth() + 1).toString().padStart(2, '0') + - __runtime.getDate().toString().padStart(2, '0') + "-" + - __runtime.getHours().toString().padStart(2, '0') + - __runtime.getMinutes().toString().padStart(2, '0') + - __runtime.getSeconds().toString().padStart(2, '0'); - - -const { flush, config, defaultUser } = require(__srcdir + '/utils/influxUtils'); - -global.__screenShotDir = process.cwd() + "/" + __config.screenshot_dir + "/" + __runtimeStr; -global.__dataBuffer = {}; - -fs.mkdirSync(__screenShotDir, { recursive: true }); - -var common = '--require "src/step_definitions/**/*.js" --require hooks.js --require-module babel-core/register '; - -let caps = new Capabilities(); -caps.set('enableVNC', true); -//caps.set('enableVideo', true); -caps.set('pageLoadStrategy', 'normal'); - -let chromeUserPreferences = { 'download.prompt_for_download': false, "download.default_directory": __config.download_dir }; -let windowSize = { "width": 1024, "height": 768 }; - -console.log("DEBUG chromeUserPreferences " + JSON.stringify(chromeUserPreferences)); - -if(__config.window_size){ - windowSize.width = parseInt(__config.window_size.width); - windowSize.height = parseInt(__config.window_size.height); -} - -console.log("DEBUG windowSize " + JSON.stringify(windowSize)); - -let logPrefs = new logging.Preferences(); -logPrefs.setLevel(logging.Type.BROWSER, logging.Level.ALL); -logPrefs.setLevel(logging.Type.DRIVER, logging.Level.INFO); - -let chromeArguments = ['--no-sandbox']; - -if(__config.sel_docker){ - chromeArguments.push('--disable-dev-shm-usage') -} - -if(__config.headless) { - caps.set('applicationCacheEnabled', false); - - switch (__config.browser.toLowerCase()) { - case "chrome": - global.__wdriver = new Builder() - .withCapabilities(caps) - .forBrowser(__config.browser) - .setChromeOptions(new chrome.Options().headless() - .addArguments(chromeArguments) - .setUserPreferences(chromeUserPreferences) - .setLoggingPrefs(logPrefs) - .windowSize({width: windowSize.width, height: windowSize.height})) - .build(); - break; - case "firefox": - global.__wdriver = new Builder() - .forBrowser(__config.browser) - .setFirefoxOptions(new ffox.Options().headless().windowSize({width: windowSize.width, - height: windowSize.height})) - .build(); - break; - - } -}else{ - switch (__config.browser.toLowerCase()) { - case "chrome": - global.__wdriver = new Builder() - .withCapabilities(caps) - .forBrowser(__config.browser) - .setChromeOptions(new chrome.Options().addArguments("--incognito") - .addArguments(chromeArguments) - .setUserPreferences(chromeUserPreferences) - .setLoggingPrefs(logPrefs) - .windowSize({width: windowSize.width, height: windowSize.height})) - .build(); - break; - case "firefox": - global.__wdriver = new Builder() - .withCapabilities(caps) - .forBrowser(__config.browser) - .build(); - break; - } -} - -__wdriver.manage().setTimeouts({implicit: 3000}); -//__wdriver.setFileDetector(LocalFileDetector); -__wdriver.executor_.w3c = true; -console.log("DEBUG __wdriver: " + JSON.stringify(__wdriver)); - -module.exports = { - 'default': common + '--format summary --format node_modules/cucumber-pretty --format json:report/cucumber_report.json', - dry: common + '--dry-run', - progress: common + '--format progress' -}; diff --git a/e2e/e2e.conf.json b/e2e/e2e.conf.json deleted file mode 100644 index 1fefd3bc9b..0000000000 --- a/e2e/e2e.conf.json +++ /dev/null @@ -1,80 +0,0 @@ -{ - "active": "development", - "development" : { - "config_id" : "development", - "influx_url": "http://localhost:8086", - "def_ctx": "/", - "headless": false, - "sel_docker": false, - "deployment": "nightly_docker", - "create_method": "REST", - "docker_name": "influx2_solo", - "browser": "chrome", - "screenshot_dir": "screenshots", - "influxdb": { - "version" : "2.0.0" - }, - "window_size": { - "width": "1024", - "height": "933" - }, - "default_user": { - "username": "admin", - "password": "changeit", - "org": "qa", - "bucket": "qa", - "token": "TEST_TOKEN" - } - }, - "nightly" : { - "config_id": "nightly", - "influx_url": "http://localhost:8086", - "def_ctx": "/", - "headless": true, - "sel_docker": false, - "deployment": "nightly_docker", - "browser": "chrome", - "screenshot_dir": "screenshots", - "create_method": "CLI_DOCKER", - "influx_path": "../bin/linux/influx", - "docker_name": "influx2_solo", - "influxdb": { - "version" : "2.0.0" - }, - "default_user": { - "username": "hibou", - "password": "ENV", - "org": "qa", - "bucket": "qa", - "token": "ENV" - } - }, - "cloud": { - "config_id" : "cloud", - "influx_url": "https://eu-central-1-1.aws.cloud2.influxdata.com", - "def_ctx": "/", - "headless": false, - "sel_docker": false, - "deployment": "cloud", - "create_method": "SKIP", - "browser": "chrome", - "screenshot_dir": "screenshots", - "influxdb": { - "version" : "2.0.0" - }, - "window_size": { - "width": "1024", - "height": "933" - }, - "default_user": { - "username": "qa1@bonitoo4influxdata.com", - "password": "ENV", - "org": "qa1@bonitoo4influxdata.com", - "bucket": "qa1A", - "orgid": "8864d10598fc08a7", - "bucketid": "7e0486a588f2f20a", - "token": "ENV" - } - - } -} diff --git a/e2e/etc/selenoid/config/browsers.json b/e2e/etc/selenoid/config/browsers.json deleted file mode 100644 index bb94aa5c55..0000000000 --- a/e2e/etc/selenoid/config/browsers.json +++ /dev/null @@ -1,48 +0,0 @@ -{ - "chrome": { - "default": "83.0", - "versions": { - "81.0": { - "image": "selenoid/chrome:81.0", - "port": "4444", - "path": "/" - }, - "83.0": { - "image": "selenoid/vnc:chrome_83.0", - "volumes": [ "/tmp/e2e/etc:/home/e2e/etc", "/tmp/e2e/downloads:/home/selenium/Downloads" ], - "port": "4444", - "path": "/" - } - } - }, - "firefox": { - "default": "77.0", - "versions": { - "76.0": { - "image": "selenoid/firefox:76.0", - "port": "4444", - "path": "/wd/hub" - }, - "77.0": { - "image": "selenoid/firefox:77.0", - "port": "4444", - "path": "/wd/hub" - } - } - }, - "opera": { - "default": "68.0", - "versions": { - "67.0": { - "image": "selenoid/opera:67.0", - "port": "4444", - "path": "/" - }, - "68.0": { - "image": "selenoid/opera:68.0", - "port": "4444", - "path": "/" - } - } - } -} diff --git a/e2e/etc/test-data/alpha_dashboard.json b/e2e/etc/test-data/alpha_dashboard.json deleted file mode 100644 index 39cdaed4a0..0000000000 --- a/e2e/etc/test-data/alpha_dashboard.json +++ /dev/null @@ -1,282 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "dashboard", - "name": "Alpha Centauri-Template", - "description": "template created from dashboard: Alpha Centurai" - }, - "content": { - "data": { - "type": "dashboard", - "attributes": { - "name": "Alpha Centauri", - "description": "" - }, - "relationships": { - "label": { - "data": [] - }, - "cell": { - "data": [ - { - "type": "cell", - "id": "04ce10261819e000" - }, - { - "type": "cell", - "id": "04ce1047b959e000" - }, - { - "type": "cell", - "id": "04ce106158d9e000" - } - ] - }, - "variable": { - "data": [] - } - } - }, - "included": [ - { - "id": "04ce10261819e000", - "type": "cell", - "attributes": { - "x": 0, - "y": 0, - "w": 4, - "h": 6 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04ce10261819e000" - } - } - } - }, - { - "id": "04ce1047b959e000", - "type": "cell", - "attributes": { - "x": 4, - "y": 0, - "w": 8, - "h": 3 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04ce1047b959e000" - } - } - } - }, - { - "id": "04ce106158d9e000", - "type": "cell", - "attributes": { - "x": 4, - "y": 3, - "w": 8, - "h": 3 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04ce106158d9e000" - } - } - } - }, - { - "type": "view", - "id": "04ce10261819e000", - "attributes": { - "name": "Hydro", - "properties": { - "shape": "chronograf-v2", - "queries": [ - { - "text": "from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r._measurement == \"hydro\")\n |> filter(fn: (r) => r._field == \"level\")", - "editMode": "advanced", - "name": "", - "builderConfig": { - "buckets": [], - "tags": [ - { - "key": "_measurement", - "values": [] - } - ], - "functions": [], - "aggregateWindow": { - "period": "auto" - } - } - } - ], - "axes": { - "x": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - }, - "y": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - } - }, - "type": "xy", - "legend": {}, - "geom": "line", - "colors": [ - { - "id": "2114e3a7-f157-4f0f-ad7c-b953d3cb7cc6", - "type": "scale", - "hex": "#31C0F6", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "3fc62935-3abc-47ba-a7ab-d44a19bbcc3f", - "type": "scale", - "hex": "#A500A5", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "a55a66a7-0f89-4608-9550-f1cae7bf3cf0", - "type": "scale", - "hex": "#FF7E27", - "name": "Nineteen Eighty Four", - "value": 0 - } - ], - "note": "", - "showNoteWhenEmpty": false, - "xColumn": "_time", - "yColumn": "_value", - "shadeBelow": false, - "hoverDimension": "y" - } - } - }, - { - "type": "view", - "id": "04ce1047b959e000", - "attributes": { - "name": "Sinusoid", - "properties": { - "shape": "chronograf-v2", - "queries": [ - { - "text": "from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r._measurement == \"sine\")\n |> filter(fn: (r) => r._field == \"beat\")", - "editMode": "advanced", - "name": "", - "builderConfig": { - "buckets": [], - "tags": [ - { - "key": "_measurement", - "values": [] - } - ], - "functions": [], - "aggregateWindow": { - "period": "auto" - } - } - } - ], - "axes": { - "x": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - }, - "y": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - } - }, - "type": "xy", - "legend": {}, - "geom": "line", - "colors": [ - { - "id": "2114e3a7-f157-4f0f-ad7c-b953d3cb7cc6", - "type": "scale", - "hex": "#31C0F6", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "3fc62935-3abc-47ba-a7ab-d44a19bbcc3f", - "type": "scale", - "hex": "#A500A5", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "a55a66a7-0f89-4608-9550-f1cae7bf3cf0", - "type": "scale", - "hex": "#FF7E27", - "name": "Nineteen Eighty Four", - "value": 0 - } - ], - "note": "", - "showNoteWhenEmpty": false, - "xColumn": "_time", - "yColumn": "_value", - "shadeBelow": false, - "hoverDimension": "y" - } - } - }, - { - "type": "view", - "id": "04ce106158d9e000", - "attributes": { - "name": "Name this Cell", - "properties": { - "shape": "chronograf-v2", - "type": "markdown", - "note": "This is just a test dashboard to be used for import." - } - } - } - ] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/bad-template.json b/e2e/etc/test-data/bad-template.json deleted file mode 100644 index 0967ef424b..0000000000 --- a/e2e/etc/test-data/bad-template.json +++ /dev/null @@ -1 +0,0 @@ -{} diff --git a/e2e/etc/test-data/hydro-test-template.json b/e2e/etc/test-data/hydro-test-template.json deleted file mode 100644 index 5b7f43ee25..0000000000 --- a/e2e/etc/test-data/hydro-test-template.json +++ /dev/null @@ -1,176 +0,0 @@ -{ - "meta": { - "name": "Hydro test dashboard-Template", - "type": "dashboard", - "description": "template created from dashboard: Hydro test dashboard", - "version": "1", - "createdAt": "2019-10-21T12:46:22.452466985Z", - "updatedAt": "2019-10-21T12:46:22.452467111Z" - }, - "content": { - "data": { - "attributes": { - "description": "", - "name": "Hydro test dashboard" - }, - "relationships": { - "cell": { - "data": [ - { - "id": "04a79573194a5000", - "type": "cell" - }, - { - "id": "04a795c71d4a5000", - "type": "cell" - } - ] - }, - "label": { - "data": [] - }, - "variable": { - "data": [] - } - }, - "type": "dashboard" - }, - "included": [ - { - "attributes": { - "h": 4, - "w": 4, - "x": 0, - "y": 0 - }, - "id": "04a79573194a5000", - "relationships": { - "view": { - "data": { - "id": "04a79573194a5000", - "type": "view" - } - } - }, - "type": "cell" - }, - { - "attributes": { - "h": 4, - "w": 4, - "x": 4, - "y": 0 - }, - "id": "04a795c71d4a5000", - "relationships": { - "view": { - "data": { - "id": "04a795c71d4a5000", - "type": "view" - } - } - }, - "type": "cell" - }, - { - "attributes": { - "name": "Name this Cell", - "properties": { - "axes": { - "x": { - "base": "10", - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "scale": "linear", - "suffix": "" - }, - "y": { - "base": "10", - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "scale": "linear", - "suffix": "" - } - }, - "colors": [ - { - "hex": "#31C0F6", - "id": "f583e27b-5ada-4eb2-9ac6-37af00f3c016", - "name": "Nineteen Eighty Four", - "type": "scale", - "value": 0 - }, - { - "hex": "#A500A5", - "id": "26bb82bd-364a-4ff6-b0ce-5905adc15bf2", - "name": "Nineteen Eighty Four", - "type": "scale", - "value": 0 - }, - { - "hex": "#FF7E27", - "id": "932f9e8b-1aee-49b7-841a-238bb2a73ea9", - "name": "Nineteen Eighty Four", - "type": "scale", - "value": 0 - } - ], - "geom": "line", - "legend": {}, - "note": "", - "queries": [ - { - "builderConfig": { - "aggregateWindow": { - "period": "auto" - }, - "buckets": [], - "functions": [], - "tags": [ - { - "key": "_measurement", - "values": [] - } - ] - }, - "editMode": "advanced", - "name": "", - "text": "from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r._measurement == \"hydro\")\n |> filter(fn: (r) => r._field == \"level\")" - } - ], - "shadeBelow": false, - "hoverDimension": "y", - "shape": "chronograf-v2", - "showNoteWhenEmpty": false, - "type": "xy", - "xColumn": "_time", - "yColumn": "_value" - } - }, - "id": "04a79573194a5000", - "type": "view" - }, - { - "attributes": { - "name": "Name this Cell", - "properties": { - "note": "This is dashboard shows randomized hydrological data for a month time window. To see the curve set the time window to at least 2d. ", - "shape": "chronograf-v2", - "type": "markdown" - } - }, - "id": "04a795c71d4a5000", - "type": "view" - } - ] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/line-protocol-bogus.txt b/e2e/etc/test-data/line-protocol-bogus.txt deleted file mode 100644 index e8154fb15d..0000000000 --- a/e2e/etc/test-data/line-protocol-bogus.txt +++ /dev/null @@ -1 +0,0 @@ -bad data diff --git a/e2e/etc/test-data/note-dboard-template.json b/e2e/etc/test-data/note-dboard-template.json deleted file mode 100644 index d6038907a5..0000000000 --- a/e2e/etc/test-data/note-dboard-template.json +++ /dev/null @@ -1,68 +0,0 @@ -{ - "meta": { - "name": "Note Dashboard-Template", - "type": "dashboard", - "description": "template created from dashboard: Note Dashboard", - "version": "1", - "createdAt": "2019-10-21T14:16:31.163226513Z", - "updatedAt": "2019-10-21T14:16:31.163226637Z" - }, - "content": { - "data": { - "attributes": { - "description": "", - "name": "Note Dashboard" - }, - "relationships": { - "cell": { - "data": [ - { - "id": "04a7aa8e284a5000", - "type": "cell" - } - ] - }, - "label": { - "data": [] - }, - "variable": { - "data": [] - } - }, - "type": "dashboard" - }, - "included": [ - { - "attributes": { - "h": 4, - "w": 4, - "x": 0, - "y": 0 - }, - "id": "04a7aa8e284a5000", - "relationships": { - "view": { - "data": { - "id": "04a7aa8e284a5000", - "type": "view" - } - } - }, - "type": "cell" - }, - { - "attributes": { - "name": "Name this Cell", - "properties": { - "note": "This dashboard just contains a note", - "shape": "chronograf-v2", - "type": "markdown" - } - }, - "id": "04a7aa8e284a5000", - "type": "view" - } - ] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/notepad-test-template.json b/e2e/etc/test-data/notepad-test-template.json deleted file mode 100644 index 7392063693..0000000000 --- a/e2e/etc/test-data/notepad-test-template.json +++ /dev/null @@ -1,100 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "dashboard", - "name": "Notepad-Template", - "description": "template created from dashboard: Notepad" - }, - "content": { - "data": { - "type": "dashboard", - "attributes": { - "name": "Notepad", - "description": "" - }, - "relationships": { - "label": { - "data": [] - }, - "cell": { - "data": [ - { - "type": "cell", - "id": "04a8ab4020f81000" - }, - { - "type": "cell", - "id": "04a8ab5327b81000" - } - ] - }, - "variable": { - "data": [] - } - } - }, - "included": [ - { - "id": "04a8ab4020f81000", - "type": "cell", - "attributes": { - "x": 0, - "y": 0, - "w": 4, - "h": 4 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04a8ab4020f81000" - } - } - } - }, - { - "id": "04a8ab5327b81000", - "type": "cell", - "attributes": { - "x": 4, - "y": 0, - "w": 4, - "h": 4 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04a8ab5327b81000" - } - } - } - }, - { - "type": "view", - "id": "04a8ab4020f81000", - "attributes": { - "name": "Name this Cell", - "properties": { - "shape": "chronograf-v2", - "type": "markdown", - "note": "Simple note 1" - } - } - }, - { - "type": "view", - "id": "04a8ab5327b81000", - "attributes": { - "name": "Name this Cell", - "properties": { - "shape": "chronograf-v2", - "type": "markdown", - "note": "Simple note 2" - } - } - } - ] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/sine-test-template.json b/e2e/etc/test-data/sine-test-template.json deleted file mode 100644 index 645d8439bb..0000000000 --- a/e2e/etc/test-data/sine-test-template.json +++ /dev/null @@ -1,174 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "dashboard", - "name": "Sinusoid test data-Template", - "description": "template created from dashboard: Sinusoid test data" - }, - "content": { - "data": { - "type": "dashboard", - "attributes": { - "name": "Sinusoid test data", - "description": "" - }, - "relationships": { - "label": { - "data": [] - }, - "cell": { - "data": [ - { - "type": "cell", - "id": "04a8a9fb2f381000" - }, - { - "type": "cell", - "id": "04a8aa39b4b81000" - } - ] - }, - "variable": { - "data": [] - } - } - }, - "included": [ - { - "id": "04a8a9fb2f381000", - "type": "cell", - "attributes": { - "x": 0, - "y": 0, - "w": 4, - "h": 4 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04a8a9fb2f381000" - } - } - } - }, - { - "id": "04a8aa39b4b81000", - "type": "cell", - "attributes": { - "x": 4, - "y": 0, - "w": 4, - "h": 4 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04a8aa39b4b81000" - } - } - } - }, - { - "type": "view", - "id": "04a8a9fb2f381000", - "attributes": { - "name": "Beat goes on", - "properties": { - "shape": "chronograf-v2", - "queries": [ - { - "text": "from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r._measurement == \"sine\")\n |> filter(fn: (r) => r._field == \"beat\")", - "editMode": "advanced", - "name": "", - "builderConfig": { - "buckets": [], - "tags": [ - { - "key": "_measurement", - "values": [] - } - ], - "functions": [], - "aggregateWindow": { - "period": "auto" - } - } - } - ], - "axes": { - "x": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - }, - "y": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - } - }, - "type": "xy", - "legend": {}, - "geom": "line", - "colors": [ - { - "id": "07cc0b96-91db-4751-9548-e99502e7e825", - "type": "scale", - "hex": "#31C0F6", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "81273781-dae1-4432-b8cd-7f5e235d632f", - "type": "scale", - "hex": "#A500A5", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "b8f3e7e2-4e5c-4e43-9604-7ae2f7295876", - "type": "scale", - "hex": "#FF7E27", - "name": "Nineteen Eighty Four", - "value": 0 - } - ], - "note": "", - "showNoteWhenEmpty": false, - "xColumn": "_time", - "yColumn": "_value", - "shadeBelow": false, - "hoverDimension": "y" - } - } - }, - { - "type": "view", - "id": "04a8aa39b4b81000", - "attributes": { - "name": "Name this Cell", - "properties": { - "shape": "chronograf-v2", - "type": "markdown", - "note": "Data generated over a 1 month time frame, so use at least 2d window to get a proper view. " - } - } - } - ] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/tau_ceti_dashboard.json b/e2e/etc/test-data/tau_ceti_dashboard.json deleted file mode 100644 index 9d1812b499..0000000000 --- a/e2e/etc/test-data/tau_ceti_dashboard.json +++ /dev/null @@ -1,282 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "dashboard", - "name": "Tau Ceti-Template", - "description": "template created from dashboard: Tau Ceti" - }, - "content": { - "data": { - "type": "dashboard", - "attributes": { - "name": "Tau Ceti", - "description": "" - }, - "relationships": { - "label": { - "data": [] - }, - "cell": { - "data": [ - { - "type": "cell", - "id": "04ce423aabd9e000" - }, - { - "type": "cell", - "id": "04ce4313b159e000" - }, - { - "type": "cell", - "id": "04ce43c11ad9e000" - } - ] - }, - "variable": { - "data": [] - } - } - }, - "included": [ - { - "id": "04ce423aabd9e000", - "type": "cell", - "attributes": { - "x": 0, - "y": 0, - "w": 12, - "h": 4 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04ce423aabd9e000" - } - } - } - }, - { - "id": "04ce4313b159e000", - "type": "cell", - "attributes": { - "x": 0, - "y": 4, - "w": 7, - "h": 2 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04ce4313b159e000" - } - } - } - }, - { - "id": "04ce43c11ad9e000", - "type": "cell", - "attributes": { - "x": 7, - "y": 4, - "w": 5, - "h": 2 - }, - "relationships": { - "view": { - "data": { - "type": "view", - "id": "04ce43c11ad9e000" - } - } - } - }, - { - "type": "view", - "id": "04ce423aabd9e000", - "attributes": { - "name": "Hydro derivative", - "properties": { - "shape": "chronograf-v2", - "queries": [ - { - "text": "from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r._measurement == \"hydro\")\n |> filter(fn: (r) => r._field == \"level\")\n |> derivative(unit: v.windowPeriod, nonNegative: false)\n |> yield(name: \"derivative\")", - "editMode": "advanced", - "name": "", - "builderConfig": { - "buckets": [], - "tags": [ - { - "key": "_measurement", - "values": [] - } - ], - "functions": [], - "aggregateWindow": { - "period": "auto" - } - } - } - ], - "axes": { - "x": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - }, - "y": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - } - }, - "type": "xy", - "legend": {}, - "geom": "line", - "colors": [ - { - "id": "6b3be0c4-ed87-4df3-b849-94ab15e9a254", - "type": "scale", - "hex": "#31C0F6", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "1b30d357-e796-493b-a423-38aa3c850980", - "type": "scale", - "hex": "#A500A5", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "871f9ba2-5042-4643-a0a0-355b76f5990b", - "type": "scale", - "hex": "#FF7E27", - "name": "Nineteen Eighty Four", - "value": 0 - } - ], - "note": "", - "showNoteWhenEmpty": false, - "xColumn": "_time", - "yColumn": "_value", - "shadeBelow": false, - "hoverDimension": "y" - } - } - }, - { - "type": "view", - "id": "04ce4313b159e000", - "attributes": { - "name": "Sinusoid sum - missed points", - "properties": { - "shape": "chronograf-v2", - "queries": [ - { - "text": "from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r._measurement == \"sine\")\n |> filter(fn: (r) => r._field == \"beat\")\n |> aggregateWindow(every: 1h, fn: sum)\n |> yield(name: \"sum\")", - "editMode": "advanced", - "name": "", - "builderConfig": { - "buckets": [], - "tags": [ - { - "key": "_measurement", - "values": [] - } - ], - "functions": [], - "aggregateWindow": { - "period": "auto" - } - } - } - ], - "axes": { - "x": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - }, - "y": { - "bounds": [ - "", - "" - ], - "label": "", - "prefix": "", - "suffix": "", - "base": "10", - "scale": "linear" - } - }, - "type": "xy", - "legend": {}, - "geom": "line", - "colors": [ - { - "id": "6b3be0c4-ed87-4df3-b849-94ab15e9a254", - "type": "scale", - "hex": "#31C0F6", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "1b30d357-e796-493b-a423-38aa3c850980", - "type": "scale", - "hex": "#A500A5", - "name": "Nineteen Eighty Four", - "value": 0 - }, - { - "id": "871f9ba2-5042-4643-a0a0-355b76f5990b", - "type": "scale", - "hex": "#FF7E27", - "name": "Nineteen Eighty Four", - "value": 0 - } - ], - "note": "", - "showNoteWhenEmpty": false, - "xColumn": "_time", - "yColumn": "_value", - "shadeBelow": false, - "hoverDimension": "y" - } - } - }, - { - "type": "view", - "id": "04ce43c11ad9e000", - "attributes": { - "name": "Name this Cell", - "properties": { - "shape": "chronograf-v2", - "type": "markdown", - "note": "This is just a test dashboard. Ceci n'est qu'un tableau d'essai. Tohle jsou jen zkusebni deska. " - } - } - } - ] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/test_deadman_crit_check.json b/e2e/etc/test-data/test_deadman_crit_check.json deleted file mode 100644 index b2b28c82a8..0000000000 --- a/e2e/etc/test-data/test_deadman_crit_check.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "id":null, - "type":"deadman", - "status":"active", - "activeStatus":"active", - "name":"Deadman Crit Check", - "query": - { - "name":"", - "text":"from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r[\"_measurement\"] == \"test\")\n |> filter(fn: (r) => r[\"_field\"] == \"val\")", - "editMode":"builder", - "builderConfig": - { - "buckets":["qa"], - "tags":[{"key":"_measurement","values":["test"],"aggregateFunctionType":"filter"},{"key":"_field","values":["val"],"aggregateFunctionType":"filter"},{"key":"gen","values":[],"aggregateFunctionType":"filter"}], - "functions":[] - }, - "hidden":false - }, - "orgID":"05a7c4e449675000", - "labels":[], - "every":"5s", - "level":"CRIT", - "offset":"2s", - "reportZero":false, - "staleTime":"1m", - "statusMessageTemplate":"Check: ${ r._check_name } is: ${ r._level }", - "tags":[], - "timeSince":"30s" -} diff --git a/e2e/etc/test-data/test_threshold_check.json b/e2e/etc/test-data/test_threshold_check.json deleted file mode 100644 index b1bc56e270..0000000000 --- a/e2e/etc/test-data/test_threshold_check.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "id":null, - "type":"threshold", - "status":"active", - "activeStatus":"active", - "name":"Threshold Check from File", - "query":{ - "name":"", - "text":"from(bucket: \"qa\")\n |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n |> filter(fn: (r) => r[\"_measurement\"] == \"test\")\n |> filter(fn: (r) => r[\"_field\"] == \"val\")\n |> aggregateWindow(every: 5s, fn: mean)\n |> yield(name: \"mean\")", - "editMode":"builder", - "builderConfig": { - "buckets":["qa"], - "tags":[ - {"key":"_measurement","values":["test"],"aggregateFunctionType":"filter"}, - {"key":"_field","values":["val"],"aggregateFunctionType":"filter"}, - {"key":"gen","values":[],"aggregateFunctionType":"filter"} - ], - "functions":[ - {"name":"mean"} - ], - "aggregateWindow":{"period":"5s"} - }, - "hidden":false - }, - "orgID":"05a67e89563c3000", - "labels":[], - "every":"5s", - "offset":"1s", - "statusMessageTemplate":"Check: ${ r._check_name } is: ${ r._level }", - "tags":[], - "thresholds":[ - {"type":"greater","value":7.5,"level":"CRIT"}, - {"type":"lesser","value":1.5,"level":"WARN"}, - {"type":"range","level":"INFO","min":4.5,"max":5.5,"within":true} - ] -} diff --git a/e2e/etc/test-data/variable-csv-arsenal.json b/e2e/etc/test-data/variable-csv-arsenal.json deleted file mode 100644 index 8523e2d909..0000000000 --- a/e2e/etc/test-data/variable-csv-arsenal.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "variable", - "name": "Arsenal-Template", - "description": "template created from variable: Arsenal" - }, - "content": { - "data": { - "type": "variable", - "attributes": { - "name": "Arsenal", - "arguments": { - "type": "constant", - "values": [ - "Henry", - "Wright", - "Bastin", - "Radford", - "Brain", - "Drake", - "Lishman", - "van Persie", - "Hulme", - "Jack" - ] - }, - "selected": [ - "Henry" - ] - }, - "relationships": { - "variable": { - "data": [] - }, - "label": { - "data": [] - } - } - }, - "included": [] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/variable-csv-slavia.json b/e2e/etc/test-data/variable-csv-slavia.json deleted file mode 100644 index 90e4c9cac7..0000000000 --- a/e2e/etc/test-data/variable-csv-slavia.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "variable", - "name": "Slavia-Template", - "description": "template created from variable: Slavia" - }, - "content": { - "data": { - "type": "variable", - "attributes": { - "name": "Slavia", - "arguments": { - "type": "constant", - "values": [ - "cestina", - "polstina", - "slovenstina", - "serbstina", - "chorvatstina", - "bosenstina", - "bulharstina", - "ukranstina", - "belorustina", - "rustina" - ] - }, - "selected": [ - "cestina" - ] - }, - "relationships": { - "variable": { - "data": [] - }, - "label": { - "data": [] - } - } - }, - "included": [] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/variable-empty.json b/e2e/etc/test-data/variable-empty.json deleted file mode 100644 index 0967ef424b..0000000000 --- a/e2e/etc/test-data/variable-empty.json +++ /dev/null @@ -1 +0,0 @@ -{} diff --git a/e2e/etc/test-data/variable-map-jehlicnany.json b/e2e/etc/test-data/variable-map-jehlicnany.json deleted file mode 100644 index 4c1d1c9e1c..0000000000 --- a/e2e/etc/test-data/variable-map-jehlicnany.json +++ /dev/null @@ -1,39 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "variable", - "name": "Jehlicnany-Template", - "description": "template created from variable: Jehlicnany" - }, - "content": { - "data": { - "type": "variable", - "attributes": { - "name": "Jehlicnany", - "arguments": { - "type": "map", - "values": { - "borovice": "pinus", - "jedle": "abies", - "modrin": "larix", - "tis": "taxus", - "zerav": "tuje" - } - }, - "selected": [ - "jedle" - ] - }, - "relationships": { - "variable": { - "data": [] - }, - "label": { - "data": [] - } - } - }, - "included": [] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/variable-map-ryby.json b/e2e/etc/test-data/variable-map-ryby.json deleted file mode 100644 index c62960d792..0000000000 --- a/e2e/etc/test-data/variable-map-ryby.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "variable", - "name": "Ryby-Template", - "description": "template created from variable: Ryby" - }, - "content": { - "data": { - "type": "variable", - "attributes": { - "name": "Ryby", - "arguments": { - "type": "map", - "values": { - "kapr": "Cyprinus carpio", - "lin": "Tinca tinca", - "losos": "Salmo salar", - "pstruh": "Salmo trutta", - "sih": "Coregonus" - } - }, - "selected": null - }, - "relationships": { - "variable": { - "data": [] - }, - "label": { - "data": [] - } - } - }, - "included": [] - }, - "labels": [] -} diff --git a/e2e/etc/test-data/variable-query-bucket.json b/e2e/etc/test-data/variable-query-bucket.json deleted file mode 100644 index bb54bed2c0..0000000000 --- a/e2e/etc/test-data/variable-query-bucket.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - "meta": { - "version": "1", - "type": "variable", - "name": "bucket-Template", - "description": "template for variable - bucket" - }, - "content": { - "data": { - "type": "variable", - "attributes": { - "name": "Bucket", - "arguments": { - "type": "query", - "values": { - "query": "buckets()\n |> filter(fn: (r) => r.name !~ /^_/)\n |> rename(columns: {name: \"_value\"})\n |> keep(columns: [\"_value\"])\n", - "language": "flux" - } - }, - "selected": null - }, - "relationships": { - "variable": { - "data": [] - }, - "label": { - "data": [] - } - } - }, - "included": [] - }, - "labels": [] -} diff --git a/e2e/features/dashboards/cellEdit.feature b/e2e/features/dashboards/cellEdit.feature deleted file mode 100644 index cf0eb3dc88..0000000000 --- a/e2e/features/dashboards/cellEdit.feature +++ /dev/null @@ -1,694 +0,0 @@ -@feature-dashboards -@dashboards-cellEdit -Feature: Dashboards - Dashboard - Cell Edit - As a user I want to Create and Update Cells - So that I can view specific Influxdbv2 data - -@tested - Scenario: Load Cell Edit View - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Dashboards" -# When hover over the "Dashboards" menu item -# When click nav sub menu "Dashboards" - Then the Dashboards page is loaded - When API sign in user "DEFAULT" - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 2880, "measurement":"pulse", "start": "-48h", "algo": "log", "prec": "sec", "name": "beat"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 7200, "measurement":"signal", "start": "-30d", "algo": "sine", "prec": "sec", "name": "foo"} - """ - When click the empty Create dashboard dropdown button - When click the create dashboard item "New Dashboard" - Then the new dashboard page is loaded - Then the empty dashboard contains a documentation link - Then the empty dashboard contains Add a Cell button - When name dashboard "Fitness" - - # +page-title - edit name this cell # covered in dashboard test - # +Graph dropdown - # +cog-cell--button - # +cancel-cell-edit--button - # +save-cell--button # already covered in dashboard test - # time-machine--view - # +empty-graph--no-queries - # +giraffe-autosizer - # +raw-data-table - # time-machine--bottom - # +raw-data--toggle - # +CSV download - # +Refresh Rate - # +Reload - # +Time Range - # +switch-to-script-editor - # +Submit# - # +Add Query - # +Queries - # +Builder - # +Schema navigator - # +Aggregate functions - # +Script Editor - # +Aggregate functions - # +Variables - -@tested - Scenario: Exercise Basic Cell Edit Controls - When click the empty create cell button - Then the cell edit overlay is loaded as "Name this Cell" - When name dashboard cell "Kliky" - When click dashboard cell edit cancel button - Then there is no dashboard cell named "Kliky" - When click the empty create cell button - Then the cell edit overlay is loaded as "Name this Cell" - When name dashboard cell "Kliky" - When click the dashboard cell view type dropdown - Then the dashboard cell view type dropdown list contains: - """ - xy,line-plus-single-stat,heatmap,histogram,single-stat,gauge,table,scatter - """ - When click the dashboard cell view type dropdown - Then the cell view type dropdown list is not present - When click cell view customize button - Then the view options container is present - Then the cell view customize button is highlighted - When click cell view customize button - Then the view options container is not present - Then the cell view customize button is not highlighted - Then the time machine view empty queries graph is visible - When click time machine autorefresh dropdown - Then the time machine autorefresh dropdown list contains: - """ - Paused,5s,10s,30s,60s - """ - When select the time machine autorefresh rate "60s" - Then the time machine force refresh button is not present - When click time machine autorefresh dropdown - When select the time machine autorefresh rate "Paused" - Then the time machine force refresh button is present - When click the cell edit Time Range Dropdown - Then the time machine Time Range dropdown list contains: - """ - Custom Time Range,Past 5m,Past 15m,Past 1h,Past 6h,Past 12h,Past 24h,Past 2d,Past 7d,Past 30d - """ - When click the cell edit Time Range Dropdown - Then the time machine Time Range dropdown list is not present - Then the time machine query builder is visible - When click the cell edit Script Editor button - Then the time machine flux editor is visible - When click the cell edit Query Builder button - When click the time machine flux editor - Then the time machine flux editor is visible - Then the time machine switch to Query Builder warning is not present - When click the cell edit Query Builder button - When click the cell edit Query Builder confirm button - Then the time machine query builder is visible - Then the time machine switch to Query Builder warning is not present - Then the time machine flux editor is not present - When click dashboard cell save button - Then the dashboard contains a cell named "Kliky" - - # ~~page-title -- name edit - # ~~Graph drop down - # ~~cog-cell--button - # cancel-cell-edit--button - # save-cell-edit--button - # ~~time-machine--view - # ~~empty-graph--no-queries - # time-machine--bottom - # ~~Refresh Rate -- N.B. pause has update button which disappears with other refresh rate values - # ~~Time Range - # ~~switch-to-script-editor - # ~~switch-to-query-builder - -@tested - Scenario: Exercise Query Builder - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - Then the cell edit overlay is loaded as "Kliky" - Then the time machine cell edit submit button is disabled - Then the edit cell bucket selector contains buckets: - """ - qa,_monitoring,_tasks - """ - When filter the time machine bucket selector with "t" - Then the edit cell bucket selector contains buckets: - """ - _monitoring,_tasks - """ - Then the bucket "qa" is not present in the time machine bucket selector - When clear the time machine bucket selector filter - Then the edit cell bucket selector contains buckets: - """ - qa,_monitoring,_tasks - """ - When click the time machine bucket selector item "_monitoring" - Then time machine builder card "1" contains the empty tag message - When click the time machine bucket selector item "qa" - Then there are "1" time machine builder cards - Then time machine builder card "1" contains: - """ - beat,foo - """ - When click the tag selector dropdown of builder card "1" - Then the tag selector dropdown of builder card "1" contains: - """ - _field,_measurement,test - """ - When click the tag selector dropdown item "_field" of builder card "1" - Then time machine builder card "1" contains: - """ - pulse,signal - """ - When click the tag selector dropdown of builder card "1" - When click the tag selector dropdown item "_measurement" of builder card "1" - Then time machine builder card "1" contains: - """ - beat,foo - """ - When filter the tags in time machine builder card "1" with "eat" - Then time machine builder card "1" does not contain "foo" - When click the tag "beat" in builder card "1" - Then the time machine cell edit submit button is enabled - Then there are "2" time machine builder cards - Then time machine builder card "2" contains: - """ - pulse - """ - When filter the tags in time machine builder card "2" with "ratfink" - Then time machine builder card "2" is empty - When clear the tags filter in time machine builder card "2" - Then time machine builder card "2" contains: - """ - pulse - """ - When clear the tags filter in time machine builder card "1" - Then time machine builder card "1" contains: - """ - beat,foo - """ - When click the tag "foo" in builder card "1" - Then time machine builder card "2" contains: - """ - pulse,signal - """ - Then the selector count for builder card "1" contains the value "2" - When click the tag selector dropdown of builder card "2" - Then the tag selector dropdown of builder card "2" contains: - """ - _field,test - """ - When click the tag selector dropdown of builder card "2" - Then the contents of tag selector dropodwn of build card "2" are not present - When click the tag "foo" in builder card "1" - Then the selector count for builder card "1" contains the value "1" - When click the tag "beat" in builder card "1" - Then the selector counf for builder card "1" is not present - Then the delete button for builder card "1" is not present - When click delete for builder card "2" - Then there are "1" time machine builder cards - # Check coverage of issue 16682 once fixed - -@tested - Scenario: Exercise Query Builder Functions - # TODO 16682 - following will not have been reset - # Then the time machine query builder function duration period is "auto" - When click the tag "beat" in builder card "1" - Then the time machine query builder function duration period is "auto (10s)" - When click the custom function group - Then the query builder function list contains - """ - mean, median, max, min, sum, derivative, nonnegative derivative, distinct, count, increase, - skew, spread, stddev, first, last, unique, sort - """ - # 7.8.20 - filter feature no longer present -# When filter the query builder function list with "rx" -# Then the query builder function list has "0" items -# When clear the query builder function lis filter -# Then the query builder function list contains -# """ -# mean, median, max, min, sum, derivative, nonnegative derivative, distinct, count, increase, -# skew, spread, stddev, first, last, unique, sort -# """ -# When filter the query builder function list with "in" -# Then the query builder function list contains -# """ -# min,distinct,increase -# """ -# Then the query builder function list has "3" items - When click the time machine query builder function custom duration tab - When click the time machine query builder function duration input - Then the query builder function duration suggestion drop down contains "12" suggestions - Then the query builder function duration suggestion drop down includes - """ - 5s,15s,1m,5m,15m,1h,6h,12h,24h,2d,7d,30d - """ - When click the query builder function duration suggestion "7d" - Then the time machine query builder function duration period is "7d" - When click the time machine query builder function duration input - When click the time machine query builder function auto duration tab - # When click the query builder function duration suggestion "auto (10s)" - Then the time machine query builder function duration period is "auto (10s)" - When click dashboard cell edit cancel button - -@tested - Scenario: Create basic query - Then the cell named "Kliky" contains the empty graph message - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - Then the time machine view no results is visible - Then the time machine cell edit submit button is disabled - When click the time machine bucket selector item "qa" - When click the tag "beat" in builder card "1" - Then the time machine cell edit submit button is enabled - When click the tag "pulse" in builder card "2" - When click the time machine cell edit submit button - Then the time machine cell edit preview graph is shown - Then the time machine cell edit preview axes are shown - -@error-collateral - Scenario: Resize Preview - When get metrics of time machine cell edit preview - When get metrics of time machine query builder - When get time machine preview canvas - When get time machine preview axes - ## Resize - larger - When resize time machine preview area by "{ "dw": "0", "dh": "+200" }" - # When wait "3" seconds - # Compare new dims Dashboard steps 387 - Then the time machine preview area has changed by "{ "dw": "0", "dh": "+200" }" - Then the time machine query builder area has changed by "{ "dw": "0", "dh": "-200" }" - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - # Git dims again - When get metrics of time machine cell edit preview - When get metrics of time machine query builder - When get time machine preview canvas - When get time machine preview axes - # Resize - smaller - When resize time machine preview area by "{ "dw": "0", "dh": "-300" }" - # Compare new dims - Then the time machine preview area has changed by "{ "dw": "0", "dh": "-300" }" - Then the time machine query builder area has changed by "{ "dw": "0", "dh": "+300" }" - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click dashboard cell save button - Then the cell named "Kliky" contains a graph - -@error-collateral - Scenario: Create Second Query - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - Then the time machine cell edit preview graph is shown - Then the time machine cell edit preview axes are shown - Then the bucket selected in the current time machine query is "qa" - Then the tag selected in the current time machine query card "1" is "beat" - Then the tag selected in the current time machine query card "2" is "pulse" - When get time machine preview canvas - When get time machine preview axes - When click the time machine query builder add query button - Then the bucket selected in the current time machine query is "qa" - Then there are "1" time machine builder cards - Then time machine builder card "1" contains: - """ - beat,foo - """ - Then there are no selected tags in time machine builder card "1" - When click the tag "foo" in builder card "1" - When click the tag "signal" in builder card "2" - When click the query builder function "mean" - When click the time machine query builder function custom duration tab - When click the time machine query builder function duration input - When click the query builder function duration suggestion "1m" - When click the time machine cell edit submit button - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click dashboard cell save button - Then the graph of the cell "Kliky" has changed - -@error-collateral - Scenario: Change Query Name - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - Then query "Query 1" is the active query in query builder - When click on query "Query 2" in the query builder - Then the bucket selected in the current time machine query is "qa" - Then the tag selected in the current time machine query card "1" is "foo" - Then the tag selected in the current time machine query card "2" is "signal" - Then the functions selected in the current time machine query card are "mean" - When right click on the time machine query tab title "Query 2" - When click the time machine query tab right click menu item "Edit" - When enter "Dotaz B" into the time machine query tab name input - Then there is no time machine query tab named "Query 2" - Then query "Dotaz B" is the active query in query builder - -@error-collateral - Scenario: Hide Query - When get time machine preview canvas - When get time machine preview axes - When click hide query of time machine query tab "Dotaz B" - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When get time machine preview canvas - When get time machine preview axes - When click hide query of time machine query tab "Dotaz B" - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click dashboard cell save button - -@tested - Scenario: Delete Second Query - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When get the current graph of the cell "Kliky" - When right click the time machine query tab "Dotaz B" - When get time machine preview canvas - When get time machine preview axes - #When click delete of time machine query tab "Dotaz B" - When click the time machine query tab right click menu item "remove" - Then there is no time machine query tab named "Dotaz B" - Then there are "1" time machine query tabs - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click dashboard cell save button - Then the graph of the cell "Kliky" has changed - -@tested - Scenario: Edit Query - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When get time machine preview canvas - When get time machine preview axes - When click the cell edit Script Editor button - Then the time machine script editor contains - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "beat") - |> filter(fn: (r) => r["_field"] == "pulse") - |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false) - |> yield(name: "mean") - """ - When change the time machine script editor contents to: - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "foo") - |> filter(fn: (r) => r["_field"] == "signal") - """ - When click the time machine cell edit submit button - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click the cell edit save button - Then the graph of the cell "Kliky" has changed - -@tested - Scenario: Switch to Query Builder - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - Then the time machine script editor contains - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "foo") - |> filter(fn: (r) => r["_field"] == "signal") - """ - When get time machine preview canvas - When get time machine preview axes - When click the cell edit Query Builder button - Then the time machine switch to Query Builder warning is present - When click the time machine flux editor - Then the time machine switch to Query Builder warning is not present - When click the cell edit Query Builder button - When click the cell edit Query Builder confirm button - Then the time machine query builder is visible - # Issue 16731 todo - check how query is reflected in query builder state - # 7.8.20 On change no longer changes canvas - #Then the time machine preview canvas has changed - #Then the time machine preview axes have changed - When click dashboard cell edit cancel button - Then the graph of the cell "Kliky" has not changed - -@tested - Scenario: Edit invalid query - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - Then the time machine script editor contains - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "foo") - |> filter(fn: (r) => r["_field"] == "signal") - """ - When change the time machine script editor contents to: - """ - Muffin Man - """ - When click the time machine cell edit submit button - Then the time machine preview canvas is not present - Then the time machine preview canvas axes are not present - Then the time machine empty graph error message is: - """ - error @1:1-1:7: undefined identifier Muffin - """ - When click the cell edit save button - Then the cell named "Kliky" contains a graph error - # Popover has been replaced with message in cell - #When hover over the error icon of the cell "Kliky" - Then the cell error message of the cell named "Kliky" is: - """ - error @1:1-1:7: undefined identifier Muffin - """ - -@tested - Scenario: Exercise Add functions - Query Builder - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When click the cell edit Query Builder button - When click the cell edit Query Builder confirm button - # TODO Clean up garbage from issue 16731 - When close all time machine builder cards - When unselect any tags in time machine builder card "1" - When click the time machine bucket selector item "qa" - When click the tag "beat" in builder card "1" - Then the time machine cell edit submit button is enabled - When click the tag "pulse" in builder card "2" - When click the time machine cell edit submit button - When get time machine preview canvas - When get time machine preview axes - When click the time machine query builder function auto duration tab - #When click the time machine query builder function duration input - #When click the query builder function duration suggestion "auto (10s)" - When click the query builder function "mean" - When click the time machine cell edit submit button - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When get time machine preview canvas - When get time machine preview axes - When click the time machine query builder function custom duration tab - When click the time machine query builder function duration input - When click the query builder function duration suggestion "1m" - When click the time machine cell edit submit button - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When get time machine preview canvas - When get time machine preview axes - When click the custom function group - When click the query builder function "mean" - When click the query builder function "derivative" - When click the time machine cell edit submit button - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When get time machine preview canvas - When get time machine preview axes - When click the query builder function "derivative" - When click the time machine cell edit submit button - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click dashboard cell save button - Then the cell named "Kliky" contains a graph - -@tested - Scenario: Edit Query - Exercise functions - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When click the cell edit Script Editor button - Then the time machine script editor contains - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "beat") - |> filter(fn: (r) => r["_field"] == "pulse") - |> aggregateWindow(every: 1m, fn: mean, createEmpty: false) - |> yield(name: "mean") - """ - Then the time machine query edit function categories are displayed: - """ - Aggregates,Inputs,Type Conversions,Selectors,Transformations,Outputs,Miscellaneous,Tests - """ - When filter the time machine query edit function list with "average" - Then the following function are visible in the time machine function list: - """ - exponentialMovingAverage,movingAverage,timedMovingAverage,highestAverage,lowestAverage - """ - Then the following function are not visible in the time machine function list: - """ - doubleEMA,pearsonr,sum,first,lowestCurrent - """ - When clear the time machine query edit function list filter - Then the following function are visible in the time machine function list: - """ - doubleEMA,pearsonr,sum,first,lowestCurrent - """ - When hover over time machine query edit function "skew" - Then the time machine query edit function popup description contains: - """ - Outputs the skew of non-null records as a float. - """ - Then the time machine query edit function popup snippet contains: - """ - skew(column: "_value") - """ - When hover over the time machine query editor submit button - Then the time machine query edit function popup is not visible - When click dashboard cell edit cancel button - -@tested - Scenario: Edit Query - Add a Function - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When click the cell edit Script Editor button - Then the time machine script editor contains - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "beat") - |> filter(fn: (r) => r["_field"] == "pulse") - |> aggregateWindow(every: 1m, fn: mean, createEmpty: false) - |> yield(name: "mean") - """ - When get time machine preview canvas - When get time machine preview axes - When click the time machine flux editor - #When click the time machine query editor function "aggregateWindow" - When click inject the time machine query editor function "aggregateWindow" - Then the time machine script editor contains - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "beat") - |> filter(fn: (r) => r["_field"] == "pulse") - |> aggregateWindow(every: 1m, fn: mean, createEmpty: false) - |> yield(name: "mean") - |> aggregateWindow(every: v.windowPeriod, fn: mean) - """ - # In CircleCi function popup can obscure the submit button - #When click the time machine flux editor - When click the filter functions input - When click the time machine cell edit submit button - Then the time machine preview canvas has changed - When click the cell edit save button - Then the graph of the cell "Kliky" has changed - -@error-collateral - Scenario: Change time range - When get the current graph of the cell "Kliky" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When get time machine preview canvas - When get time machine preview axes - When click the cell edit Time Range Dropdown - When select the cell edit Time Range "past24h" - #When click the time machine flux editor - When click the filter functions input - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click the cell edit save button - Then the graph of the cell "Kliky" has changed - Then the dashboard Time Range Dropdown selected contains "Past 24h" - #When click the dashboard Time Range Dropdown - #When select dashboard Time Range "24h" - #Then the graph of the cell "Kliky" has changed - -@error-collateral - Scenario: View raw data - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When get time machine preview canvas - When get time machine preview axes - Then the time machine raw data table is not present - When click time machine raw data toggle - Then the time machine raw data table is present - Then the time machine preview canvas is not present - When click time machine raw data toggle - Then the time machine preview canvas has changed - Then the time machine raw data table is not present - When click dashboard cell edit cancel button - Then the cell named "Kliky" contains a graph - - -@error-collateral @download-file - Scenario: Download results as CSV - When remove files ".*chronograf_data.csv" if exists - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When click time machine download CSV - Then a file matching ".*chronograf_data.csv" exists - When verify first CSV file matching ".*chronograf_data.csv" as containing - """ - { "_time": "type:date", "_value": "type:double", "_field": "pulse", "_measurement": "beat", "test": "generic" } - """ - When click dashboard cell edit cancel button - Then the cell named "Kliky" contains a graph - -@error-collateral - Scenario: Refresh Rates - #earlier signin may have timed out - When API sign in user "DEFAULT" - When toggle context menu of dashboard cell named "Kliky" - When click cell content popover configure - When get time machine preview canvas - When get time machine preview axes - When wait "20" seconds - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 5, "measurement":"pulse", "start": "-5m", "algo": "log", "prec": "sec", "name": "beat"} - """ - Then the time machine force refresh button is present - Then the time machine autorefresh dropdown list is set to "Paused" - When click time machine force refresh - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When get time machine preview canvas - When get time machine preview axes - When click time machine autorefresh dropdown - When select the time machine autorefresh rate "10s" - Then the time machine force refresh button is not present - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 5, "measurement":"pulse", "start": "-5m", "algo": "log", "prec": "sec", "name": "beat"} - """ - When wait "20" seconds - Then the time machine preview canvas has changed - Then the time machine preview axes have changed - When click time machine autorefresh dropdown - When select the time machine autorefresh rate "Paused" - When get time machine preview canvas - When get time machine preview axes - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 5, "measurement":"pulse", "start": "-5m", "algo": "log", "prec": "sec", "name": "beat"} - """ - When wait "20" seconds - Then the time machine preview canvas has not changed diff --git a/e2e/features/dashboards/dashboard.feature b/e2e/features/dashboards/dashboard.feature deleted file mode 100644 index 321dce99a2..0000000000 --- a/e2e/features/dashboards/dashboard.feature +++ /dev/null @@ -1,350 +0,0 @@ -@feature-dashboards -@dashboards-dashboard -Feature: Dashboards - Dashboard - Base - As a user I want to Read Create Update and Delete a Dashboard - So that I can view specific Influxdbv2 data - -@tested - Scenario: Load Initial Dashboard view - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Dashboards" -# When hover over the "Dashboards" menu item -# When click nav sub menu "Dashboards" - Then the Dashboards page is loaded - When API sign in user "DEFAULT" - When API create a label "Cesko" described as "Pravda vitezi" with color "#AAFFAA" for user "DEFAULT" - When API create a label "Mesto" described as "Matka mest" with color "#FFAAAA" for user "DEFAULT" - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 120, "measurement":"level", "start": "-30d", "algo": "hydro", "prec": "sec", "name": "foo"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 120, "measurement":"beat", "start": "-30d", "algo": "sine", "prec": "sec", "name": "bar"} - """ - When click the empty Create dashboard dropdown button - When click the create dashboard item "New Dashboard" - Then the new dashboard page is loaded - Then the empty dashboard contains a documentation link - Then the empty dashboard contains Add a Cell button - When name dashboard "про́бный прибо́ров" - -@error-collateral - Scenario: Exercise Dashboard Dropdowns - When click dashboard time locale dropdown - Then the active dashboard dropdown contains items: - """ - Local,UTC - """ - When click dashboard refresh dropdown - Then the active dashboard dropdown contains dividers: - """ - Refresh - """ - Then the active dashboard dropdown contains items: - """ - Paused,5s,10s,15s,30s,60s - """ - When click dashboard time range dropdown - Then the active dashboard dropdown contains dividers: - """ - Time Range - """ - Then the active dashboard dropdown contains items: - """ - Custom Time Range,Past 5m,Past 15m,Past 1h,Past 6h,Past 12h,Past 24h,Past 2d,Past 7d,Past 30d - """ - -@tested - Scenario: Create Cell - When click the empty create cell button - Then the cell edit overlay is loaded as "Name this Cell" - When name dashboard cell "вре́менный" - When click dashboard cell edit cancel button - Then there is no dashboard cell named "вре́менный" - When click the empty create cell button - Then the cell edit overlay is loaded as "Name this Cell" - When name dashboard cell "вре́менный" - When click dashboard cell save button - Then the dashboard contains a cell named "вре́менный" - - #Currently failing due to issue #16619 -@tested - Scenario: Add Note to Cell - When toggle context menu of dashboard cell named "вре́менный" - When click cell content popover add note - Then the edit note popup is loaded - Then dismiss the popup - Then popup is not loaded - When toggle context menu of dashboard cell named "вре́менный" - When click cell content popover add note - Then click note popup cancel - Then popup is not loaded - When toggle context menu of dashboard cell named "вре́менный" - When click cell content popover add note - When enter the cell note popup CodeMirror text: - """ - __Шинель__\n - _Гоголь_\n -В департаменте… но лучше не называть в каком департаменте... - """ - Then the cell note popup Markdown preview panel contains - """ -В департаменте… но лучше не называть в каком департаменте... - """ - When click the cell note popup save button - Then popup is not loaded - Then the cell named "вре́менный" has a note indicator - When click the note indicator of the "вре́менный" cell - Then the cell note popover contains: - """ -В департаменте… но лучше не называть в каком департаменте... - """ - When click the cell title "вре́менный" - Then the cell note popover is not loaded - When toggle context menu of dashboard cell named "вре́менный" - Then the cell content popover has item edit note - When click the cell title "вре́менный" - Then the cell content popover is not loaded - -@tested - Scenario: Edit Cell Note - When toggle context menu of dashboard cell named "вре́менный" - When click cell content popover add note - Then the edit note popup is loaded - Then the cell note popup Code Mirror text contains: - """ - В департаменте… но лучше не называть в каком департаменте... - """ - Then the cell note popup Code Mirror text contains: - """ - _Гоголь_ - """ - Then the cell note popup Code Mirror text contains: - """ - __Шинель__ - """ - Then the cell note popup Markdown preview panel contains - """ -В департаменте… но лучше не называть в каком департаменте... - """ - When clear the cell note popup Code Mirror text - Then the cell note popup markup preview panel has no text - When enter the cell note popup CodeMirror text: - """ - __LE MANTEAU__\n - _Nikolaï Gogol_\n -Dans une administration russe... mieux vaut ne pas dire le nom de cette administration ... - """ - Then the cell note popup Markdown preview panel contains - """ -Dans une administration russe... mieux vaut ne pas dire le nom de cette administration ... - """ - When click the cell note popup save button - Then popup is not loaded - When click the note indicator of the "вре́менный" cell - Then the cell note popover contains: - """ -Dans une administration russe... mieux vaut ne pas dire le nom de cette administration ... - """ - When click the cell title "вре́менный" - Then the cell content popover is not loaded - -@error-collateral - Scenario: Move cell - When get metrics of cell named "вре́менный" - When move the cell named "вре́менный" by "{ "dx": "+400", "dy": "+200" }" - # Y is 0 below because of float to top feature - cells float to top row when repositioned - Then the location of the cell named "вре́менный" is changed by "{ "dx": "+400", "dy": "0" }" - When get metrics of cell named "вре́менный" - When move the cell named "вре́менный" by "{ "dx": "-400", "dy": "+200" }" - Then the location of the cell named "вре́менный" is changed by "{ "dx": "-400", "dy": "0" }" - When get metrics of cell named "вре́менный" - When move the cell named "вре́менный" by "{ "dx": "0", "dy": "+200" }" - Then the location of the cell named "вре́менный" is changed by "{ "dx": "0", "dy": "0" }" - When move the cell named "вре́менный" by "{ "dx": "+400", "dy": "+200" }" - When get metrics of cell named "вре́менный" - When click nav menu item "home" - #When hover over the "Dashboards" menu item - #When click nav menu item "home" - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - When click the dashboard name "про́бный прибо́ров" - Then the dashboard named "про́бный прибо́ров" is loaded - Then the location of the cell named "вре́менный" is unchanged - When move the cell named "вре́менный" by "{ "dx": "-400", "dy": "0" }" - -@tested - Scenario: Edit Cell - Simple - Then the cell named "вре́менный" contains the empty graph message - When toggle context menu of dashboard cell named "вре́менный" - When click cell content popover configure - Then the cell edit overlay is loaded as "вре́менный" - When get the current cell edit preview graph - When click the cell edit Time Range Dropdown - When select the cell edit Time Range "Past 30d" - When click the cell edit Script Editor button - When paste into cell edit Script Editor - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r._measurement == "foo") - |> filter(fn: (r) => r._field == "level") - """ - When click the time machine cell edit submit button - Then the time machine cell edit preview graph is shown - Then the cell edit preview graph is changed - When click the cell edit save button - When click the dashboard Time Range Dropdown - When select dashboard Time Range "30d" - Then the cell named "вре́менный" contains a graph - -@error-collateral - Scenario: Resize Cell - When get the current graph of the cell "вре́менный" - When get metrics of cell named "вре́менный" - When resize the cell name "вре́менный" by "{ "dw": "+300", "dh": "+100" }" - Then the graph of the cell "вре́менный" has changed - Then size of the cell named "вре́менный" has changed by "{ "dw": "+300", "dh": "+100" }" - # Leave then return check TODO after issue 16180 fixed - #When get the current graph of the cell "вре́менный" - #When get metrics of cell named "вре́менный" - #When hover over the "Dashboards" menu item - #When click nav menu item "home" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - #When click the dashboard name "про́бный прибо́ров" - #Then the dashboard named "про́бный прибо́ров" is loaded - #Then the size of the of the cell named "вре́менный" is unchangd - -@error-collateral - Scenario: Hover Cell Graph - When hover over the graph of the cell named "вре́менный" - Then the cell graph data point infobox is visible - -@error-collateral - Scenario: Zoom Cell horizontal - When get the current graph of the cell "вре́менный" - When move horizontally to "2/5" of graph cell named "вре́менный" - When drag horizontally to "3/5" of graph cell named "вре́менный" - Then the graph of the cell "вре́менный" has changed - -@error-collateral - Scenario: Unzoom Cell - When get the current graph of the cell "вре́менный" - When Click at the point "{"x": "1/2", "y": "1/2"}" of graph cell named "вре́менный" - Then the graph of the cell "вре́менный" has changed - -@error-collateral - Scenario: Zoom Cell vertical - When get the current graph of the cell "вре́менный" - When move vertically to "2/5" of graph cell named "вре́менный" - When drag vertically to "3/5" of graph cell named "вре́менный" - Then the graph of the cell "вре́менный" has changed - -@error-collateral - Scenario: Unzoom Cell 2 - When get the current graph of the cell "вре́менный" - When Click at the point "{"x": "1/2", "y": "1/2"}" of graph cell named "вре́менный" - Then the graph of the cell "вре́менный" has changed - -@tested - Scenario: Rename Cell - When toggle context menu of dashboard cell named "вре́менный" - When click cell content popover configure - Then the cell edit overlay is loaded as "вре́менный" - When click on the cell edit name - When change the cell edit name to "dočasný" - When click the cell edit save button - Then the cell named "dočasný" is visible in the dashboard - -@tested - Scenario: Clone Cell - When toggle context menu of dashboard cell named "dočasný" - When click cell edit content popover clone - Then the cell named "dočasný (Clone)" is visible in the dashboard - When toggle context menu of dashboard cell named "dočasný (Clone)" - When click cell content popover configure - When clear the cell edit Script Editor - When paste into cell edit Script Editor - """ - from(bucket: "qa") -|> range(start: v.timeRangeStart, stop: v.timeRangeStop) -|> filter(fn: (r) => r._measurement == "foo") -|> filter(fn: (r) => r._field == "level") -|> movingAverage(n: 5) - """ - When click the time machine cell edit submit button - When click on the cell edit name - When change the cell edit name to "klouzavý průměr" - When click the cell edit save button - Then the graph of the cell "dočasný" differs from "klouzavý průměr" - # Following step fails due to issue #16619 - When click the note indicator of the "klouzavý průměr" cell - Then the cell note popover contains: - """ -Dans une administration russe... mieux vaut ne pas dire le nom de cette administration ... - """ - When click the cell title "klouzavý průměr" - Then the cell content popover is not loaded - -@error-collateral - Scenario: Two cells column to row - When get metrics of cell named "dočasný" - When get metrics of cell named "klouzavý průměr" - When move the cell named "dočasný" by "{ "dx": "+300", "dy": "0" }" - Then the location of the cell named "klouzavý průměr" is changed by "{ "dx": "0", "dy": "-380" }" - -@error-collateral - Scenario: Two cells row to column - When get metrics of cell named "dočasný" - When get metrics of cell named "klouzavý průměr" - When move the cell named "dočasný" by "{ "dx": "-300", "dy": "0" }" - Then the location of the cell named "klouzavý průměr" is changed by "{ "dx": "0", "dy": "+380" }" - -@error-collateral - Scenario: Two cells enlarge first into second - When get metrics of cell named "klouzavý průměr" - When move the cell named "dočasný" by "{ "dx": "+300", "dy": "0" }" - Then the location of the cell named "klouzavý průměr" is changed by "{ "dx": "0", "dy": "-380" }" - When get metrics of cell named "dočasný" - When get metrics of cell named "klouzavý průměr" - When resize the cell name "klouzavý průměr" by "{ "dw": "+300", "dh": "0" }" - Then the location of the cell named "dočasný" is changed by "{ "dx": "0", "dy": "+380" }" - Then size of the cell named "klouzavý průměr" has changed by "{ "dw": "+300", "dh": "0" }" - -@error-collateral - Scenario: Two cells reduce first when above second - When get metrics of cell named "dočasný" - When get metrics of cell named "klouzavý průměr" - When resize the cell name "klouzavý průměr" by "{ "dw": "-300", "dh": "0" }" - Then the location of the cell named "dočasný" is changed by "{ "dx": "0", "dy": "-380" }" - Then size of the cell named "klouzavý průměr" has changed by "{ "dw": "-300", "dh": "0" }" - -@error-collateral - Scenario: Two cells column to row - Moved cell drops down - When get metrics of cell named "dočasný" - When get metrics of cell named "klouzavý průměr" - When move the cell named "dočasný" by "{ "dx": "-150", "dy": "150" }" - Then the location of the cell named "dočasný" is changed by "{ "dx": "-150", "dy": "+380" }" - -@tested - Scenario Outline: Delete Cell - When toggle context menu of dashboard cell named "" - When click cell content popover delete - When click cell content popover delet confirm - # following should be notification-primary [data-testid=notification-primary] - #Then the success notification contains "Cell deleted from dashboard" - Then the primary notification contains "Cell deleted from dashboard" - Then close all notifications - Then the cell named "" is no longer present - Examples: - |NAME| - |klouzavý průměr| - |dočasný | - -# TODO - Dark Mode / Light Mode diff --git a/e2e/features/dashboards/dashboards.feature b/e2e/features/dashboards/dashboards.feature deleted file mode 100644 index e47356928c..0000000000 --- a/e2e/features/dashboards/dashboards.feature +++ /dev/null @@ -1,309 +0,0 @@ -@feature-dashboards -@dashboards-dashboards -Feature: Dashboards - Base - As a user I want to Read Create Update and Delete Dashboards - So that I can organize my data in Influxdbv2 - -@tested - Scenario: Load dashboards page - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - Then the Dashboards page is loaded - When API sign in user "DEFAULT" - When API create a label "Cesko" described as "Pravda vitezi" with color "#AAFFAA" for user "DEFAULT" - When API create a label "Mesto" described as "Matka mest" with color "#FFAAAA" for user "DEFAULT" - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 120, "measurement":"level", "start": "-30d", "algo": "hydro", "prec": "sec", "name": "hydro"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 120, "measurement":"beat", "start": "-30d", "algo": "sine", "prec": "sec", "name": "sine"} - """ - - -@tested - Scenario: Create new dashboard - When click the empty Create dashboard dropdown button - Then the empty create dashboard dropdown list contains - """ - New Dashboard,Import Dashboard,From a Template - """ - When click the create dashboard item "New Dashboard" - Then the new dashboard page is loaded - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - Then the empty Create dashboard dropdown button is not present - Then there is a dashboard card named "Name this Dashboard" - -@tested - Scenario: Rename dashboard from card - When hover over dashboard card named "Name this Dashboard" - Then the export button for the dashboard card "Name this Dashboard" is visible - Then the clone button for the dashboard card "Name this Dashboard" is visible - Then the delete button for the dashboard card "Name this Dashboard" is visible - When hover over dashboard card name "Name this Dashboard" - When click the edit dashboard card name button for "Name this Dashboard" - When clear the name input of the dashboard card "Name this Dashboard" - When enter the new name "Mercure" in the name input of the dashboard card "Name this Dashboard" - When press the "ENTER" key - Then there is a dashboard card named "Mercure" - Then there is no dashboard card named "Name this Dashboard" - -@tested - Scenario: Add description to dashboard - Then the description for card "Mercure" contains "No description" - When hover over description of the dashboard card "Mercure" - When click the edit description button for the dashboard card "Mercure" - When enter into the dashboard card "Mercure" the description: - """ - le dieu du commerce dans la mythologie romaine - """ - When press the "ENTER" key - Then the description for card "Mercure" contains "le dieu du commerce dans la mythologie romaine" - -@tested - Scenario: Add Labels to dashboard - # Issue 16529 - possible design change - When click empty label for the dashboard card "Mercure" - Then the label "Cesko" in the popover selector is visible - Then the label "Mesto" in the popover selector is visible - Then the create new label item is not visible in the popover - When enter "Slovensko" in the popover label selector filter - Then the create new label item is visible in the popover - Then there are "0" label pills in the select label popover - When click the new label item in the add labels popover - Then the create Label popup is loaded - When dismiss the popup - Then popup is not loaded - Then the add label popover is not present - When click the add label button for the dashboard card "Mercure" - # Issue 16528 - control values not cleared - Then there are "2" label pills in the select label popover - When enter "Slovensko" in the popover label selector filter - When click the new label item in the add labels popover - When click the label popup Create Label button - Then popup is not loaded - Then the dashboard card "Mercure" has the label "Slovensko" - When hover over the label "Slovensko" of the dashboard card "Mercure" - When click remove label "Slovensko" from the dashboard card "Mercure" - Then the dashboard card "Mercure" labels empty message is visible - Then the label "Slovenkso" of the dashboard card "Mercure" is not present - When click the add label button for the dashboard card "Mercure" - Then there are "3" label pills in the select label popover - When enter "sko" in the popover label selector filter - Then there are "2" label pills in the select label popover - Then the label "Mesto" is not present in the popover selector - When clear the popover label selector filter - Then there are "3" label pills in the select label popover - # TODO use escape key once #17853 is resolved - #When press the "ESCAPE" key - When click the dashboards filter input - Then the add label popover is not present - #TODO add check for issue #17964 - -@tested - Scenario Outline: Create new Dashboard - When click create dashboard control - When click the create dashboard item "New Dashboard" - When name dashboard "" - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - Then there is a dashboard card named "" - - Examples: - |NAME| - |Terre| - |Venus| - |Jupiter| - |Mars | - -@tested - Scenario: Access Dashboard from home page - When hover over the "home" menu item - When click nav menu item "home" - Then the dashboards panel contains links: - """ - Mercure,Venus,Terre,Mars,Jupiter - """ - When click the dashboards panel link "Mercure" - Then the dashboard named "Mercure" is loaded - -@tested - Scenario: Filter Dashboard Cards - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - Then the dashboards page contains the cards: - """ - Mercure,Venus,Terre,Mars,Jupiter - """ - When enter the term "ter" in the dashboards filter - Then the dashboards page contains the cards: - """ - Terre,Jupiter - """ - Then the dashboards page does not contain the cards: - """ - Mercure,Venus,Mars - """ - When clear the dashboards filter - Then the dashboards page contains the cards: - """ - Mercure,Venus,Terre,Mars,Jupiter - """ - -@error-collateral - Scenario: Import Dashboard from file - When click create dashboard control - When click the create dashboard item "Import Dashboard" - Then the Import Dashboard popup is loaded - When upload the import dashboard file "etc/test-data/alpha_dashboard.json" - Then the import dashboard drag and drop header contains success "etc/test-data/alpha_dashboard.json" - When click the Import Dashboard button - Then popup is not loaded - Then the success notification contains "Successfully imported dashboard." - Then close all notifications - Then there is a dashboard card named "Alpha Centauri" - -@tested - Scenario: Import Dashboard paste json - When click create dashboard control - When click the create dashboard item "Import Dashboard" - Then the Import Dashboard popup is loaded - When click the Import Dashboard popup radio button Paste Json - Then the Import Dashboard file upload control is not present - When paste contents of file "etc/test-data/tau_ceti_dashboard.json" into the JSON textarea - When click the Import Dashboard button - Then popup is not loaded - Then the success notification contains "Successfully imported dashboard." - Then close all notifications - Then there is a dashboard card named "Tau Ceti" - -@tested - Scenario: Create Dashboard from template - When create a new template from the file "etc/test-data/sine-test-template.json" for user "DEFAULT" - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - Then the Dashboards page is loaded - When click create dashboard control - When click the create dashboard item "From a Template" - Then the Create Dashboard from Template popup is loaded - Then the Dashboard from Template create button is disabled - When click Dashboard from Template popup cancel button - Then popup is not loaded - When click create dashboard control - When click the create dashboard item "From a Template" - Then dismiss the popup - Then popup is not loaded - When click create dashboard control - When click the create dashboard item "From a Template" - When click the template item "Sinusoid test data-Template" - Then the template preview cell "Beat goes on" is visible - When click Dashboard from Template create button - Then there is a dashboard card named "Sinusoid test data" - -@tested - Scenario: Sort Dashboards by Name - When close all notifications - Then the dashboards are sorted as: - """ - Alpha Centauri,Jupiter,Mars,Mercure,Sinusoid test data,Tau Ceti,Terre,Venus - """ - When click dashboards sort type dropdown - When click dashboards sort by "Name Desc" - #When click dashboards sort by name - Then the dashboards are sorted as: - """ - Venus,Terre,Tau Ceti,Sinusoid test data,Mercure,Mars,Jupiter,Alpha Centauri - """ - When click dashboards sort type dropdown - When click dashboards sort by "Name Asc" - Then the dashboards are sorted as: - """ - Alpha Centauri,Jupiter,Mars,Mercure,Sinusoid test data,Tau Ceti,Terre,Venus - """ - # Scenario: Sort Dashboards by Modified time - # TODO - implement after issue #15610 is resolved - -@error-collateral - Scenario: Export Dashboard as Template - When hover over dashboard card named "Alpha Centauri" - When click export of the dashboard card named "Alpha Centauri" - When click confirm export of the dashboard card "Alpha Centauri" - When click Export Dashboard popup Save as Template - Then the success notification contains "Successfully saved dashboard as template" - Then a REST template document for user "DEFAULT" titled "Alpha Centauri-Template" exists - Then close all notifications - -@error-collateral - Scenario: Export Dashboard copy to clipboard - When hover over dashboard card named "Jupiter" - When click export of the dashboard card named "Jupiter" - When click confirm export of the dashboard card "Jupiter" - When click Export Dashboard popup Copy to Clipboard - Then the success notification contains "Copied dashboard to the clipboard" - Then close all notifications -#N.B. clipboard not accessible for comparison in headless mode - When click the Export Dashboard dismiss button - Then popup is not loaded - -@error-collateral @download-file - Scenario: Export Dashboard to file - When remove file "tau_ceti.json" if exists - When hover over dashboard card named "Tau Ceti" - When click export of the dashboard card named "Tau Ceti" - When click confirm export of the dashboard card "Tau Ceti" - Then the Export Dashboard popup is loaded - When click the Export Dashboard dismiss button - Then popup is not loaded - When hover over dashboard card named "Tau Ceti" - When click export of the dashboard card named "Tau Ceti" - When click confirm export of the dashboard card "Tau Ceti" - When click Export Dashboard popup Download JSON for "tau_ceti.json" - Then popup is not loaded - Then the file "tau_ceti.json" has been downloaded - When remove file "tau_ceti.json" if exists - -@tested - Scenario: Clone Dashboard - When hover over dashboard card named "Tau Ceti" - When click clone of the dashboard card named "Tau Ceti" - When click the clone confirm of dashboard card "Tau Ceti" - Then the dashboard named "Tau Ceti (clone 1)" is loaded - Then the dashboard contains a cell named "Hydro derivative" - Then the dashboard contains a cell named "Sinusoid sum - missed points" - Then the dashboard contains a cell named "Note" - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - Then there is a dashboard card named "Tau Ceti (clone 1)" - -@tested - Scenario Outline: Delete dashboards - When hover over dashboard card named "" - When click delete of dashboard card "" - When click delete confirm of dashboard card "" - Then the success notification contains "Dashboard deleted successfully" - When close all notifications - Then there is no dashboard card named "" - - Examples: - |NAME| - |Mercure| - |Terre| - |Venus| - |Jupiter| - |Mars| - |Alpha Centauri| - |Tau Ceti| - |Tau Ceti (clone 1)| - |Sinusoid test data| diff --git a/e2e/features/dashboards/noteCell.feature b/e2e/features/dashboards/noteCell.feature deleted file mode 100644 index bdf8ec94db..0000000000 --- a/e2e/features/dashboards/noteCell.feature +++ /dev/null @@ -1,91 +0,0 @@ -@feature-dashboards -@dashboards-noteCell -Feature: Dashboards - Dashboard - Note Cell - As a user I want to Add a Note Cell - So that I can provide specific static information - -# Show note when query return no data makes little sense -# Uses Code Mirror still - - Scenario: Create basic dashboard for notes - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Dashboards" -# When hover over the "Dashboards" menu item -# When click nav sub menu "Dashboards" - Then the Dashboards page is loaded - When click the empty Create dashboard dropdown button - When click the create dashboard item "New Dashboard" - Then the new dashboard page is loaded - Then the empty dashboard contains a documentation link - Then the empty dashboard contains Add a Cell button - When name dashboard "Rumcajs" - - #N.B. expecting the toggle "show when query returns no data" to not be present - # TODO #17412 - add check that toggle not present to detect any regression - Scenario: Exercise Add Note popup controls - When click dashboard add note button - # N.B. add guide link check - Then main "Add" note popup is loaded - #Then the query no data toggle is not present - Then dismiss the popup - Then popup is not loaded - When click dashboard add note button - Then click note popup cancel - Then popup is not loaded - - Scenario: Add Note with markdown - When click dashboard add note button - When enter the cell note popup CodeMirror text: - """ - # Večerníček - ## Rumcajs - - **Loupežník Rumcajs** je _pohádková postava_ z [Večerníčku](https://cs.wikipedia.org/wiki/Ve%C4%8Dern%C3%AD%C4%8Dek), jejíž příběhy následně vyšly i knižně. - - > Jak Rumcajs vysadil duhu na nebe - - * Rumcajs - * Manka - * Cipísek - - 1. Alpha - 1. Beta - 1. Gamma - - """ - Then the main note popup markdown preview panel contains a "h1" tag with "Večerníček" - Then the main note popup markdown preview panel contains a "h2" tag with "Rumcajs" - Then the main note popup markdown preview panel contains a "strong" tag with "Loupežník Rumcajs" - Then the main note popup markdown preview panel contains a "em" tag with "pohádková postava" - Then the main note popup markdown preview panel contains a "blockquote" tag with "Jak Rumcajs vysadil duhu na nebe" - Then the main note popup markdown preview panel contains a "ul li" tag with "Rumcajs" - Then the main note popup markdown preview panel contains a "ol li" tag with "Alpha" - When click the cell note popup save button - Then popup is not loaded - Then the note cell contains a "h1" tag with "Večerníček" - Then the note cell contains a "h2" tag with "Rumcajs" - Then the note cell contains a "strong" tag with "Loupežník Rumcajs" - Then the note cell contains a "em" tag with "pohádková postava" - Then the note cell contains a "blockquote" tag with "Jak Rumcajs vysadil duhu na nebe" - Then the note cell contains a "ul li" tag with "Rumcajs" - Then the note cell contains a "ol li" tag with "Alpha" - -@tested - Scenario: Edit note - When toggle context menu of dashboard cell named "Note" - When click cell content popover edit note - Then main "Edit" note popup is loaded - # TODO edit text and verify - need to push on to higher priority tests - When click note popup cancel - - Scenario: Delete note - When toggle context menu of dashboard cell named "Note" - When click cell content popover delete - When click cell content popover delet confirm - Then the cell named "Note" is no longer present - - - diff --git a/e2e/features/dashboards/variables.feature b/e2e/features/dashboards/variables.feature deleted file mode 100644 index fc4fe462ab..0000000000 --- a/e2e/features/dashboards/variables.feature +++ /dev/null @@ -1,344 +0,0 @@ -@feature-dashboards -@dashboards-variables -Feature: Dashboards - Dashboard - Variables - As a user I want to Add Variables to cell Queries - So that I can view specific Influxdbv2 data sets - -@tested -@tested - Scenario: Load Cell Edit View - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When clear browser storage - When UI sign in user "DEFAULT" - When click nav menu item "Dashboards" - #When hover over the "Dashboards" menu item - #When click nav sub menu "Dashboards" - Then the Dashboards page is loaded - When API sign in user "DEFAULT" - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 2880, "measurement":"pulse", "start": "-48h", "algo": "log", "prec": "sec", "name": "beat"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 7200, "measurement":"signal", "start": "-30d", "algo": "sine", "prec": "sec", "name": "foo"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 2880, "measurement":"sema", "start": "-48h", "algo": "log", "prec": "sec", "name": "beat"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 2880, "measurement":"znacka", "start": "-48h", "algo": "log", "prec": "sec", "name": "beat"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 2880, "measurement":"mots", "start": "-48h", "algo": "dico", "data": ["pulse","sema","znacka","wombat"], "prec": "sec", "name": "slovo"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 2880, "measurement":"worten", "start": "-48h", "algo": "dico", "data": ["alpha","beta"], "prec": "sec", "name": "logo"} - """ - When create the "csv" variable "APIVAR" with default "[ "pulse" ]" for user "DEFAULT" with values: - """ - [ "pulse", "sema", "znacka", "hele" ] - """ - When create the "query" variable "POKUS" with default "[ "pulse" ]" for user "DEFAULT" with values: - """ - {"language":"flux","query":"from(bucket: \"qa\")\n |> range(start: -1d, stop: now() )\n |> filter(fn: (r) => r._measurement == \"slovo\")\n |> filter(fn: (r) => r._field == \"mots\")\n |> unique(column: \"_value\")"} - """ - When create the "map" variable "KARTA" with default "[ "poppy" ]" for user "DEFAULT" with values: - """ - { "poppy":"pulse","salvia":"sema","zinnia":"znacka","daisy":"duck" } - """ - When click the empty Create dashboard dropdown button - When click the create dashboard item "New Dashboard" - Then the new dashboard page is loaded - Then the empty dashboard contains a documentation link - Then the empty dashboard contains Add a Cell button - When name dashboard "Semiotic" - -@error-collateral - Scenario: Create Basic Cell for Variables - When click the empty create cell button - Then the cell edit overlay is loaded as "Name this Cell" - When name dashboard cell "Semantic" - When click the time machine bucket selector item "qa" - When click the tag "beat" in builder card "1" - Then the time machine cell edit submit button is enabled - When click the tag "pulse" in builder card "2" - When click the time machine cell edit submit button - Then the time machine cell edit preview graph is shown - Then the time machine cell edit preview axes are shown - When click dashboard cell save button - Then the dashboard contains a cell named "Semantic" - -@error-collateral - Scenario: Edit Query - Filter variables - When toggle context menu of dashboard cell named "Semantic" - When click cell content popover configure - When click the cell edit Script Editor button - Then the time machine script editor contains - """ - from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "beat") - |> filter(fn: (r) => r["_field"] == "pulse") - |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false) - |> yield(name: "mean") - """ - When click the time machine script editor variables tab - Then the time machine variables list contains - """ - APIVAR,POKUS,KARTA - """ - When enter the value "AR" in the time machine variables filter - Then the time machine variables list contains - """ - APIVAR,KARTA - """ - Then the time machine variables list does not contain - """ - POKUS - """ - When clear the time machine variables filter - Then the time machine variables list contains - """ - APIVAR,POKUS,KARTA - """ - When click dashboard cell edit cancel button - Then the dashboard contains a cell named "Semantic" - - # time-machine--bottom - # switch-to-script-editor - # Queries - # Script Editor - # Variables - -@error-collateral - Scenario: Add CSV variable to script - When toggle context menu of dashboard cell named "Semantic" - When click cell content popover configure - When click the cell edit Script Editor button - # Move to end - When send keys "CTRL+END,AUP,AUP,END" to the time machine flux editor - # Send cursor to start of field value - When send keys "ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT" to the time machine flux editor - # Delete field value - When send keys "DEL,DEL,DEL,DEL,DEL,DEL,DEL" to the time machine flux editor - # Now check then add variable - When click the time machine script editor variables tab - Then the time machine variable popover is not visible - When hover over the time machine variable "APIVAR" - Then the time machine variable popover is visible - # TODO - No solution as yet to access popover contents - all action make popover disappear - #When hover over the time machine variable "APIVAR" - # When click time machine popover variable dropodown - When click inject the time machine variable "APIVAR" - When click the time machine cell edit submit button - When click dashboard cell save button - Then the dashboard variables button is highlighted - When get the current graph of the cell "Semantic" - When click the value dropdown button for variable "APIVAR" - Then the selected item of the dropdown for variable "APIVAR" is "pulse" - Then the value dropdown for variable "APIVAR" contains - """ - pulse,sema,znacka,hele - """ - When click the item "sema" for variable "APIVAR" - Then the graph of the cell "Semantic" has changed - When get the current graph of the cell "Semantic" - Then the selected item of the dropdown for variable "APIVAR" is "sema" - When click the value dropdown button for variable "APIVAR" - When click the item "hele" for variable "APIVAR" - Then the cell named "Semantic" has no results - When click the value dropdown button for variable "APIVAR" - When click the item "znacka" for variable "APIVAR" - Then the graph of the cell "Semantic" has changed - #When click dashboard cell edit cancel button - #Then the dashboard contains a cell named "Semantic" - - - #Script with Map variables -@error-collateral - Scenario: Add Map variable to script - Then the dashboard variables button is highlighted - When toggle context menu of dashboard cell named "Semantic" - When click cell content popover configure - #When click the cell edit Script Editor button - # Move to end - When send keys "CTRL+END,AUP,AUP,END" to the time machine flux editor - # Send cursor to start of field value - When send keys "ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT" to the time machine flux editor - # Delete field value - When send keys "DEL,DEL,DEL,DEL,DEL,DEL,DEL,DEL" to the time machine flux editor - # Now check then add variable - When click the time machine script editor variables tab - Then the time machine variable popover is not visible - When hover over the time machine variable "KARTA" - Then the time machine variable popover is visible - # TODO - No solution as yet to access popover contents - all action make popover disappear - # No solution as yet to access popover contents - all action make popover disappear - #When hover over the time machine variable "KARTA" - #When click time machine popover variable dropodown - When click inject the time machine variable "KARTA" - When click the time machine cell edit submit button - When click dashboard cell save button - Then the dashboard variables button is highlighted - When get the current graph of the cell "Semantic" - When click the value dropdown button for variable "KARTA" - Then the selected item of the dropdown for variable "KARTA" is "poppy" - Then the value dropdown for variable "KARTA" contains - """ - daisy,poppy,salvia,zinnia - """ - When click the item "salvia" for variable "KARTA" - Then the graph of the cell "Semantic" has changed - When get the current graph of the cell "Semantic" - Then the selected item of the dropdown for variable "KARTA" is "salvia" - When click the value dropdown button for variable "KARTA" - When click the item "daisy" for variable "KARTA" - Then the cell named "Semantic" has no results - When click the value dropdown button for variable "KARTA" - When click the item "zinnia" for variable "KARTA" - Then the graph of the cell "Semantic" has changed - - #Script with Query variables -@error-collateral - Scenario: Add Query variable to script - Then the dashboard variables button is highlighted - When toggle context menu of dashboard cell named "Semantic" - When click cell content popover configure - #When click the cell edit Script Editor button - # Move to end - When send keys "CTRL+END,AUP,AUP,END" to the time machine flux editor - # Send cursor to start of field value - When send keys "ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT" to the time machine flux editor - # Delete field value - When send keys "DEL,DEL,DEL,DEL,DEL,DEL,DEL,DEL" to the time machine flux editor - # Now check then add variable - When click the time machine script editor variables tab - Then the time machine variable popover is not visible - When hover over the time machine variable "POKUS" - Then the time machine variable popover is visible - # TODO - No solution as yet to access popover contents - all action make popover disappear - # No solution as yet to access popover contents - all action make popover disappear - #When hover over the time machine variable "POKUS" - #When click time machine popover variable dropodown - When click inject the time machine variable "POKUS" - When click the time machine cell edit submit button - When click dashboard cell save button - Then the dashboard variables button is highlighted - When get the current graph of the cell "Semantic" - When click the value dropdown button for variable "POKUS" - Then the selected item of the dropdown for variable "POKUS" is "pulse" - Then the value dropdown for variable "POKUS" contains - """ - pulse,sema,wombat,znacka - """ - When click the item "sema" for variable "POKUS" - Then the graph of the cell "Semantic" has changed - When get the current graph of the cell "Semantic" - Then the selected item of the dropdown for variable "POKUS" is "sema" - When click the value dropdown button for variable "POKUS" - When click the item "wombat" for variable "POKUS" - Then the cell named "Semantic" has no results - When click the value dropdown button for variable "POKUS" - When click the item "znacka" for variable "POKUS" - Then the graph of the cell "Semantic" has changed - - - #Change variables in Dashboard view two cells same variable. -@error-collateral - Scenario: Change variables in Dashboard view - two cells - When click the header add cell button - Then the cell edit overlay is loaded as "Name this Cell" - When name dashboard cell "Syntagma" - When click the cell edit Script Editor button - When set the time machine script editor contents to: - """ -from(bucket: "qa") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "beat") - |> filter(fn: (r) => r["_field"] == v.POKUS) - |> aggregateWindow(every: v.windowPeriod, fn: mean) - """ - When click the time machine cell edit submit button - When click the cell edit save button - When move the cell named "Syntagma" by "{ "dx": "+400", "dy": "-200" }" - When get the current graph of the cell "Semantic" - When get the current graph of the cell "Syntagma" - When click the value dropdown button for variable "POKUS" - When click the item "pulse" for variable "POKUS" - Then the graph of the cell "Semantic" has changed - Then the graph of the cell "Syntagma" has changed - -@error-collateral - Scenario: Change variables in Dashboard view - two variables - When toggle context menu of dashboard cell named "Syntagma" - When click cell content popover configure - # Move to end - When send keys "CTRL+END" to the time machine flux editor - # Send cursor to start of field value - When send keys "AUP,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT,ALFT" to the time machine flux editor - # Delete field value - When send keys "DEL,DEL,DEL,DEL,DEL,DEL,DEL,DEL" to the time machine flux editor - # Now check then add variable - When click the time machine script editor variables tab - Then the time machine variable popover is not visible - When click inject the time machine variable "KARTA" - When click the time machine cell edit submit button - When click the cell edit save button - When click dashboard time range dropdown - When get the current graph of the cell "Semantic" - When get the current graph of the cell "Syntagma" - When select dashboard Time Range "24h" - Then the graph of the cell "Semantic" has changed - Then the graph of the cell "Syntagma" has changed - When get the current graph of the cell "Semantic" - When get the current graph of the cell "Syntagma" - When click the value dropdown button for variable "KARTA" - When click the item "daisy" for variable "KARTA" - Then the cell named "Syntagma" has no results - Then the graph of the cell "Semantic" is visible - # following check skipped - seems there is a slight change due to refresh - #Then the graph of the cell "Semantic" has not changed - - - - #Dashboard view show/hide variables. -@error-collateral - Scenario: Toggle Variables in Dashboard - Then the value dropdown for variable "POKUS" is visible - Then the dashboard variables button is highlighted - When click the dashboard variables button - Then the dashboard variables button is not highlighted - Then the value dropdown for variable "POKUS" is not visible - When click the dashboard variables button - Then the value dropdown for variable "POKUS" is visible - Then the dashboard variables button is highlighted - - #default variable - - # NEED TO CLEAN UP - # Variables cached in localstore can influence other tests -#@tested -# Scenario Outline: Delete Variable -# When click nav menu item "Settings" -# When click the settings tab "Variables" - #When hover over the "Settings" menu item - #When click nav sub menu "Variables" -# When hover over variable card named "" -# When click delete menu of variable card named "" -# When click delete confirm of variable card named "" -# Then the success notification contains "Successfully deleted the variable" -# Then the variable card "" is not present -# When close all notifications - -# Examples: -# |NAME| -# |APIVAR| -# |KARTA| -# |POKUS| diff --git a/e2e/features/dataExplorer/dataExplorer.feature b/e2e/features/dataExplorer/dataExplorer.feature deleted file mode 100644 index 1af166e61a..0000000000 --- a/e2e/features/dataExplorer/dataExplorer.feature +++ /dev/null @@ -1,176 +0,0 @@ -@feature-dataExplorer -@dataExplorer-dataExplorer -Feature: Data explorer - As a user I want to Create queries in Data Explorer - - Scenario: Create a new bucket and add data - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "LoadData" - Then the buckets tab is loaded - When click the Create Bucket button - Then the Create Bucket Popup is loaded - When input the name of the bucket as "bucket_explorer_test" - When click the Create Bucket popup Create button - Then the bucket named "bucket_explorer_test" is in the list - When click add data button for bucket "bucket_explorer_test" - Then the add data popover for the bucket "bucket_explorer_test" is visible - When click bucket card popover item "Line Protocol" - Then the first page of the Line Protocol Wizard is loaded - When click radio button "Enter Manually" - Then the data point text area is visible - When enter "12" datapoints with value named "foo" starting at "-2h" with "fibonacci" data of type "int" and prec "ms" - When click the Line Protocol wizard precision dropdown - When click the line Protocol wizard precision "ms" - #When enter "" into the line protocol text area - #When click the Line Protocol wizard continue button - When click the Line Protocol wizard write button - Then the Line Protocol wizard step status message is "Data Written Successfully" - #When click the Line Protocol wizard finish button - When click the Line Protocol wizard close button - - - Scenario: Create a simple query - #When click nav menu item "Explorer" - When click on the bucket named "bucket_explorer_test" - Then the Data Explorer page is loaded - When choose bucket named "bucket_explorer_test" - When choose the item "fibonacci" in builder card "1" - When choose the item "foo" in builder card "2" - When choose the item "bucketSteps" in builder card "3" - When click the submit button - Then the time machine graph is shown - - Scenario: Hover over graph - When hover over the graph - Then the graph data point infobox is visible - - Scenario: Zoom graph horizontal - When get the current graph - When move horizontally to "2/5" of the graph - When drag horizontally to "3/5" of the graph - Then the graph has changed - - Scenario: Unzoom graph - When get the current graph - When Click at the point "{"x": "1/2", "y": "1/2"}" of the graph - Then the graph has changed - - Scenario: Zoom graph vertical and refresh - When get the current graph - When move vertically to "2/5" of the graph - When drag vertically to "3/5" of the graph - Then the graph has changed - When click the refresh button - Then the graph has changed - - Scenario: Turn on the automatic refresh and check the graph changes - When click the refresh button - When get the current graph - When click the automatic refresh - paused - When select the automatic refresh "5s" - When wait "6" seconds - Then the graph has changed - When click the automatic refresh - active - When select the automatic refresh "paused" - - Scenario: Create second query with Script Editor - When click the time machine add query button - Then there are "2" time machine query tabs - #When right click on the time machine query tab named "Query 2" - #When click on "edit" in the query tab menu - #When input a new query tab name as "testQueryTab" - When click the Script Editor button - When paste into Script Editor text area - """ - from(bucket: "bucket_explorer_test") - |> range(start: v.timeRangeStart, stop: v.timeRangeStop) - |> filter(fn: (r) => r["_measurement"] == "fibonacci") - """ - When click the submit button - Then the time machine graph is shown - Then the graph has changed - - Scenario: Change graph view type - When click the graph view type dropdown - When select the graph view type "Graph + Single Stat" - Then the graph view type is Graph plus Single Stat - - Scenario: Change the graph time range and view raw data - When click the graph time range dropdown - When select the graph time range "6h" - Then the graph has changed - When click the filter functions input - When click the view raw data toggle - Then the raw data table is visible - - Scenario: Use aggregate function - When click the view raw data toggle - Then the time machine graph is shown - When click on the time machine query tab named "Query 1" - #When search for function "mean" - When select the function "mean" - When click the submit button - Then the graph has changed - - Scenario: Delete query tab - When right click on the time machine query tab named "Query 2" - When click on "remove" in the query tab menu - Then there are "1" time machine query tabs - - Scenario: Save query as a dashboard cell - When click on the Save as button - Then the Save as overlay is visible - When click the Target Dashboard dropdown - When select Create a New Dashboard from the Target Dashboard dropdown - When input the New Dashboard Name "Dashboard Cell Test" - When input the Cell Name "DC Test Name" - When click on the Save as Dashboard Cell button - Then the success notification contains "Created dashboard successfully" - When click nav menu item "dashboards" - Then there is a dashboard card named "Dashboard Cell Test" - When click the dashboard name "Dashboard Cell Test" - Then the cell named "DC Test Name" is visible in the dashboard - - Scenario: Save query as a task - When click nav menu item "Explorer" - When click the submit button - When click on the Save as button - When click on tab "Task" in the Save As popup - When input the Task Name "Task Test" - When input the Task Interval "4h" - When input the Task Offset "10" - When click on the Save as Task button - Then the error notification contains "Failed to create new task:" - When input the Task Offset "10m" - When click on the Save as Task button - Then the success notification contains "New task created successfully" - Then there is a task named "Task Test" - - Scenario: Save query as a variable - When click nav menu item "Explorer" - When click the submit button - When close all notifications - When click on the Save as button - When click on tab "Variable" in the Save As popup - When input the variable name "Variable Test" - When click on the Save as Variable button - Then the success notification contains "Successfully created new variable:" - When click nav menu item "Settings" - When there is a variable card for "Variable Test" - - Scenario: Delete Test Variable - When hover over variable card named "Variable Test" - When click delete menu of variable card named "Variable Test" - When click delete confirm of variable card named "Variable Test" - Then the success notification contains "Successfully deleted the variable" - Then the variable card "Variable Test" is not present - When close all notifications - - - - - - diff --git a/e2e/features/homePage/homePage.feature b/e2e/features/homePage/homePage.feature deleted file mode 100644 index 1735f39984..0000000000 --- a/e2e/features/homePage/homePage.feature +++ /dev/null @@ -1,50 +0,0 @@ -@feature-homePage -@homePage-homePage -Feature: Home Page - - Scenario: logout home page - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When open page "HOME" for user "DEFAULT" - When click logout from the home page - Then the sign in page is loaded - When UI sign in user "DEFAULT" - Then the home page is loaded - - Scenario: Click Data Collector Panel - When I click the panel "Data Collector" - Then the Telegraf Tab is loaded - -@tested - Scenario: Check Dashboards Panel - When hover over the "home" menu item - When click nav menu item "home" - When I click the panel "Dashboard" - Then the Dashboards page is loaded - When click create dashboard control - When click "New Dashboard" in create dashboard dropdown - When name dashboard "Test Dashboard" - When hover over the "home" menu item - When click nav menu item "home" - Then the dashboards panel contains a link to "Test Dashboard" - When click the dashboard link to "Test Dashboard" - Then the dashboard named "Test Dashboard" is loaded - -@tested - Scenario: Click Alerting Panel - When hover over the "home" menu item - When click nav menu item "home" - When I click the panel "Alerting" - Then the Alerting page is loaded - - Scenario: Logout from Menu - When hover over the "home" menu item - When click nav menu item "home" - When click logout from the home page - Then the sign in page is loaded - When UI sign in user "DEFAULT" - - - diff --git a/e2e/features/influx/influx.feature b/e2e/features/influx/influx.feature deleted file mode 100644 index 91bd1ad2fa..0000000000 --- a/e2e/features/influx/influx.feature +++ /dev/null @@ -1,99 +0,0 @@ -@feature-influx -@influx-influx -Feature: Influx common - Click through the controls common to all influx pages - -@tested - Scenario: Open home page - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When open page "HOME" for user "DEFAULT" - Then influx page is loaded - #Then the header contains the org name "DEFAULT" - Then the home page header contains "Getting Started" - -@tested - Scenario: Click Data Explorer - #Then the menu item text "Data Explorer" is "hidden" - #When hover over the "explorer" menu item - #Then the menu item text "Data Explorer" is "visible" - When click nav menu item "Explorer" - Then the Data Explorer page is loaded - -@tested - Scenario: Click Dashboards - #Then the menu item text "Dashboards" is "hidden" - #When hover over the "dashboards" menu item - #Then the menu item text "Dashboards" is "visible" - When click nav menu item "Dashboards" - Then the Dashboards page is loaded - -@tested - Scenario: Click Tasks - #Then the menu item text "Tasks" is "hidden" - #When hover over the "tasks" menu item - #Then the menu item text "Tasks" is "visible" - When click nav menu item "Tasks" - Then the Tasks page is loaded - -@tested - Scenario: Click Alerting - #Then the menu item text "Monitoring & Alerting" is "hidden" - #When hover over the "alerting" menu item - #Then the menu item text "Monitoring & Alerting" is "visible" - When click nav menu item "Alerting" - Then the Alerting page is loaded - -@tested - Scenario: Click Load Data - #Then the menu item text "Settings" is "hidden" - #When hover over the "loadData" menu item - #Then the menu item text "Load Data" is "visible" - #Then the menu item text "Buckets" is "visible" - #Then the menu item text "Telegraf" is "visible" - #Then the menu item text "Scrapers" is "visible" - When click nav menu item "LoadData" - Then the buckets tab is loaded - - Scenario: Click Settings - #Then the menu item text "Settings" is "hidden" - #When hover over the "settings" menu item - #Then the menu item text "Settings" is "visible" - When click nav menu item "Settings" - Then the Settings page is loaded - - # Item no longer exists commit=bd91a81123 build_date=2020-04-07T07:57:22Z - #Scenario: Hover Feedback - # Then the menu item text "Feedback" is "hidden" - # When hover over the "feedback" menu item - # Then the menu item text "Feedback" is "visible" - # Then the feedback URL should include "https://docs.google.com/forms" - - Scenario: Click home item - #Then the home submenu items are "hidden" - #When hover over the "home" menu item - #Then the home submenu items are "visible" - #When click nav sub menu "Create Organization" - #Then the Create Organization form is loaded - #When open page "HOME" for user "DEFAULT" - #When hover over the "home" menu item - When click nav menu item "home" - Then the home page is loaded - #Then the sign in page is loaded - #When UI sign in user "DEFAULT" - -# This appears to have been removed 2020-05-12 -# See closed issue #17991 -# Scenario: Click Organization -# When click nav menu item "Organization" -# Then the Organization page is loaded - - Scenario: Click User - When click nav menu item "User" - Then the user menu items are "visible" - - # TODO - create organization from Home Menu Item - - diff --git a/e2e/features/loadData/buckets.feature b/e2e/features/loadData/buckets.feature deleted file mode 100644 index ea53ad2c90..0000000000 --- a/e2e/features/loadData/buckets.feature +++ /dev/null @@ -1,276 +0,0 @@ -@feature-loadData -@loadData-buckets -Feature: Load Data - Buckets - As a user I want to Read Create Update and Delete Buckets - So that I can manage the stores used with Influxdbv2 - - -@tested -Scenario: List Initial Buckets - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "LoadData" - When click load data tab "Buckets" - Then the buckets tab is loaded - Then the buckets are sorted as "_monitoring,_tasks,DEFAULT" - -@tested -Scenario: Exercise Create Bucket Dialog - When click the Create Bucket button - Then the Create Bucket Popup is loaded - Then the Create button of Create Bucket Popup is disabled - Then the Retention Policy radio button "never" is active - Then the Retention Policy intervals controls are not present - When click the Retention Policy "intervals" button - Then the Retention Policy radio button "intervals" is active - Then the Retention Policy radio button "never" is inactive - Then the Retention Policy intervals controls are present - # N.B. controls replaced with dropdown selector 2019-09-11 - #Then the Retention Policy warning message contains "Retention period must be at least an hour" - #When enter "61" into the Retention Policy "Seconds" control - #Then the Retention Policy "Seconds" control contains the value "1" - #Then the Retention Policy "Minutes" control contains the value "1" - #Then the Retention Policy warning message contains "Retention period must be at least an hour" - #When clear all Retention Policy interval controls - #When enter "123" into the Retention Policy "Minutes" control - #Then the Retention Policy "Minutes" control contains the value "3" - #Then the Retention Policy "Hours" control contains the value "2" - #Then the Retention Policy warning message has disappeared - #When clear all Retention Policy interval controls - #When enter "80" into the Retention Policy "Hours" control - #Then the Retention Policy "Hours" control contains the value "8" - #Then the Retention Policy "Days" control contains the value "3" - #When clear all Retention Policy interval controls - #When enter "7" into the Retention Policy "Days" control - #Then the Retention Policy "Days" control contains the value "7" - #When clear all Retention Policy interval controls - #When enter "ABCD" into the Retention Policy "Seconds" control - #Then the Retention Policy "Seconds" control contains the value "0" - #When enter "ABCD" into the Retention Policy "Minutes" control - #Then the Retention Policy "Minutes" control contains the value "0" - #When enter "ABCD" into the Retention Policy "Hours" control - #Then the Retention Policy "Hours" control contains the value "0" - #When enter "ABCD" into the Retention Policy "Days" control - #Then the Retention Policy "Days" control contains the value "0" - When input the name of the bucket as "ABCD" - #Then the Retention Policy warning message contains "Retention period must be at least an hour" - When click the Retention Policy "never" button - #Then the Retention Policy warning message has disappeared - Then the Create button of Create Bucket Popup is enabled - When dismiss the Create Bucket Popup - Then the Create Bucket Popup is not present - When click the Create Bucket button - Then the Create Bucket Popup is loaded - Then the Create button of Create Bucket Popup is disabled - When cancel the Create Bucket Popup - Then the Create Bucket Popup is not present - -@tested -Scenario Outline: Create Buckets with Retention Policies - When click the Create Bucket button - When input the name of the bucket as "" - When set the retention policy of the bucket as "" - When click the Create Bucket popup Create button - Then the bucket named "" is in the list - Then the bucket named "" has a Retention Policy of "" - -Examples: - |NAME| RETENTION | - | Trvalá | Never | - | Měsíční | 30d | - | Týdenní | 7d | - | Denní | 24h | - | Půldenní | 12h | - | Hodinová | 1h | - | Oprava | 24h | - -@tested -Scenario: Modify Retention Policy - When click on settings for bucket named "Oprava" - Then the Edit Bucket popup is loaded - Then the name edit textbox of the Edit Bucket popup is disabled - Then the form help text contains "To rename bucket use the RENAME button below" - When dismiss the Edit Bucket Popup - Then the Edit Bucket Popup is not present - When click on settings for bucket named "Oprava" - Then the Edit Bucket popup is loaded - When cancel the Edit Bucket Popup - Then the Edit Bucket Popup is not present - When click on settings for bucket named "Oprava" - When set the retention policy of the bucket as "48h" - When click Edit Bucket Popup Save Changes - # N.B. fix following once issue 14905 is resolved - Then the bucket named "Oprava" has a Retention Policy of "48h" - -@tested -Scenario: Filter Buckets - When enter "denn" in the Buckets filter field - Then the buckets are sorted as "Denní,Půldenní,Týdenní" - Then the bucket "Oprava" is not in the list - -@error-collateral -Scenario: Clear Filter - When clear the Buckets filter field - Then the bucket named "Oprava" is in the list - Then the bucket named "_monitoring" is in the list - Then the bucket named "_tasks" is in the list - Then the bucket named "Týdenní" is in the list - -@tested -Scenario: Sort Buckets by Name - When click the sort type dropdown - When click sort by item "Name Desc" - #Given ensure buckets name sort order "desc" - Then the buckets are sorted as "_monitoring,_tasks,Denní,Hodinová,Měsíční,Oprava,Půldenní,DEFAULT,Trvalá,Týdenní" - When click the sort type dropdown - When click sort by item "Name Asc" - # Given ensure buckets name sort order "asc" - Then the buckets are sorted as "Týdenní,Trvalá,DEFAULT,Půldenní,Oprava,Měsíční,Hodinová,Denní,_tasks,_monitoring" - When click the sort type dropdown - When click sort by item "Name Desc" - #Given ensure buckets name sort order "desc" - -@error-collateral -Scenario: Sort Buckets by Retention Policy - When click the sort type dropdown - When click sort by item "retentionRules[0].everySeconds-asc" - #When click buckets sort by retention policy - Then the buckets are sorted as "Hodinová,Půldenní,Denní,Oprava,_tasks,Týdenní,_monitoring,Měsíční,Trvalá,DEFAULT" - When click the sort type dropdown - When click sort by item "retentionRules[0].everySeconds-desc" - #When click buckets sort by retention policy - Then the buckets are sorted as "DEFAULT,Trvalá,Měsíční,Týdenní,_monitoring,_tasks,Oprava,Denní,Půldenní,Hodinová" - -@tested -Scenario Outline: Delete Buckets -# following check leads to troublesome false positives - todo fix it -# Then the delete button of the card named "" is not present - When hover over bucket card named "" - When click the delete button of the card named "" - When click the confirm delete button of the card named "" - Then the bucket card named "" is not in the list - -Examples: - | Name | - | Trvalá | - | Měsíční | - | Týdenní | - | Denní | - | Půldenní | - | Hodinová | - | Oprava | - - -@tested -Scenario: Add Manual Line Protocol Data to Default - Then the add data popover is not present - When click add data button for bucket "DEFAULT" - Then the add data popover for the bucket "DEFAULT" is visible - When click bucket card popover item "Line Protocol" - Then the first page of the Line Protocol Wizard is loaded - When click radio button "Enter Manually" - Then the data point text area is visible - When click the Line Protocol wizard precision dropdown - When click the line Protocol wizard precision "ms" - When enter "12" datapoints with value named "foo" starting at "-2h" with "fibonacci" data of type "int" and prec "ms" - When click the Line Protocol wizard write button - Then the line Protocol wizard second step opens - Then the Line Protocol wizard step status message is "Data Written Successfully" - When click the Line Protocol wizard close button - Then the line Protocol wizard is not present - When API sign in user "DEFAULT" - Then the bucket "DEFAULT" for user "DEFAULT" contains: -""" -{ "points": 12, "field": "foo", "measurement": "fibonacci", "start": "-3h", "vals": [1,233], "rows": ["0","-1"] } -""" - -@error-collateral - Scenario: Add Manual Line Protocol Bad Data to Default - Then the add data popover is not present - When click add data button for bucket "DEFAULT" - Then the add data popover for the bucket "DEFAULT" is visible - When click bucket card popover item "Line Protocol" - Then the first page of the Line Protocol Wizard is loaded - When click radio button "Enter Manually" - Then the data point text area is visible - When enter "bad data" into the line protocol text area - When click the Line Protocol wizard write button - Then the line Protocol wizard second step opens - Then the Line Protocol wizard step status message contains "Unable to Write Data" - When click the Line Protocol wizard cancel button - Then the data point text area is visible - When click the Line Protocol wizard close icon - Then the line Protocol wizard is not present - -@tested - Scenario: Add Line Protocol Data from File to Default - When generate a line protocol testdata file "etc/test-data/line-protocol-hydro.txt" based on: - """ - { "points": 20, "measurement":"level", "start": "-60h", "algo": "hydro", "prec": "sec", "name": "hydro"} - """ - When click add data button for bucket "DEFAULT" - Then the add data popover for the bucket "DEFAULT" is visible - When click bucket card popover item "Line Protocol" - Then the first page of the Line Protocol Wizard is loaded - When click radio button "Upload File" - When add the file "etc/test-data/line-protocol-bogus.txt" to the Line Protocol Wizard file upload - Then the popup wizard import file header contains "line-protocol-bogus.txt" - When click the Line Protocol wizard write button - #When click the Line Protocol wizard continue button - Then the popup wizard step state text contains "Unable to Write Data" - # appears error class no longer being used 13.8.20 - #Then the popup wizard step is in state "error" - When click the Line Protocol wizard cancel button - #When click the bucket data wizard previous button - When click the Line Protocol wizard precision dropdown - When click the line Protocol wizard precision "ms" - When add the file "etc/test-data/line-protocol-hydro.txt" to the Line Protocol Wizard file upload - Then the popup wizard import file header contains "line-protocol-hydro.txt" - When click the Line Protocol wizard write button - #When click the Line Protocol wizard continue button - Then the popup wizard step state text contains "Data Written Successfully" - # Success class no longer used 13.8.20 - #Then the popup wizard step is in state "success" - When click the Line Protocol wizard close button - Then the line Protocol wizard is not present - #Then the bucket "DEFAULT" for user "DEFAULT" contains "20" datapoints of "hydro" data with value named "level" starting at "-60h" - Then the bucket "DEFAULT" for user "DEFAULT" contains: - """ - { "points": 20, "field": "level", "measurement": "hydro", "start": "-72h", "vals": "skip", "rows": ["0","-1"], "name": "hydro" } - """ - -@tested - Scenario: Add Scraper to Default - When click add data button for bucket "DEFAULT" - Then the add data popover for the bucket "DEFAULT" is visible - When click bucket card popover item "Scrape Metrics" - When enter the name "Courbet" into the Create Scraper popup name input - When click the create scraper create button - Then the success notification contains "Scraper was created successfully" - When click load data tab "Scrapers" - Then there is a scraper card for "Courbet" - - Scenario: Add Telegraf to Default - When click nav menu item "LoadData" - When click load data tab "Buckets" - When click add data button for bucket "DEFAULT" - Then the add data popover for the bucket "DEFAULT" is visible - When click bucket card popover item "Configure Telegraf Agent" - Then the Create Telegraf Config Wizard is loaded - When click the buckets dropdown button - When select the buckets dropdown item "DEFAULT" - When select the telegraf plugin tile "System" - When click the Popup Wizard continue button - When enter the telegraf name "Daumier" - When click the Popup Wizard continue button - Then the success notification contains "telegraf plugin: system." - Then the success notification contains "configurations have been saved" - When close all notifications - When click the Popup Wizard continue button - When click load data tab "Telegrafs" - Then there is a telegraf card for "Daumier" - - #TODO - new functionality - click bucket name opens data explorerer - diff --git a/e2e/features/loadData/clientlib.feature b/e2e/features/loadData/clientlib.feature deleted file mode 100644 index e3a619e577..0000000000 --- a/e2e/features/loadData/clientlib.feature +++ /dev/null @@ -1,52 +0,0 @@ -@feature-loadData -@loadData-clientlib -Feature: Load Data - Client Libs - As a user I want to Read Create Update and Delete Client Libraries - So that I can manage the stores used with Influxdbv2 - - Scenario: Load Initial Client Lib Tab - Given I reset the environment - Given run setup over REST "DEFAULT" - When API sign in user "DEFAULT" - When API create a bucket named "Duchamp" for user "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "LoadData" - When click load data tab "Client Libraries" - Then the Client Libraries tab is loaded - - Scenario: Open C# Popup - When click the "csharp" client library tile - Then the csharp info popup is loaded - Then click copy "Package Manager" to clipboard - Then the success notification contains "has been copied to clipboard" - #Then verify clipboard contains text of "Package Manager" - When close all notifications - Then verify the github repository link contains "influxdb-client-csharp" - Then dismiss the popup - - Scenario: Open Go Popup - When click the "go" client library tile - Then the go info popup is loaded - Then verify the github repository link contains "influxdb-client-go" - Then dismiss the popup - - Scenario: Open Java Popup - When click the "java" client library tile - Then the java info popup is loaded - Then verify the github repository link contains "influxdb-client-java" - Then dismiss the popup - - Scenario: Open Node Popup - When click the "javascript-node" client library tile - Then the node info popup is loaded - Then verify the github repository link contains "influxdb-client-js" - Then dismiss the popup - - Scenario: Open Python Popup - When click the "python" client library tile - Then the python info popup is loaded - Then verify the github repository link contains "influxdb-client-python" - Then dismiss the popup - - # TODO - check copy to clipboard buttons - N.B. clipboard not available in chromedriver headless diff --git a/e2e/features/loadData/loadData.feature b/e2e/features/loadData/loadData.feature deleted file mode 100644 index 15d3d511b4..0000000000 --- a/e2e/features/loadData/loadData.feature +++ /dev/null @@ -1,21 +0,0 @@ -@feature-loadData -@loadData-loadData -Feature: Load Data - Base - As a user I want to open the Load Data page - So that I can explore how data is being loaded into Influxdbv2 - -@tested - Scenario: Verify Tabs - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When open page "load-data" for user "DEFAULT" - When click load data tab "Buckets" - Then the buckets tab is loaded - When click load data tab "Telegrafs" - Then the Telegraf Tab is loaded - When click load data tab "Scrapers" - Then the Scrapers Tab is loaded - When click load data tab "Tokens" - Then the tokens tab is loaded diff --git a/e2e/features/loadData/scrapers.feature b/e2e/features/loadData/scrapers.feature deleted file mode 100644 index 61229e5330..0000000000 --- a/e2e/features/loadData/scrapers.feature +++ /dev/null @@ -1,156 +0,0 @@ -@feature-loadData -@loadData-scrapers -Feature: Load Data - Scrapers - As a user I want to Read Create Update and Delete Scrapers - So that I can manage the stores used with Influxdbv2 -# Move exercise create scraper popup here -# N.B. can verify scrapers at endpoint http://localhost:8086/api/v2/scrapers - - -@tested -Scenario: Load Initial Scrapers tab - Given I reset the environment - Given run setup over REST "DEFAULT" - When API sign in user "DEFAULT" - When API create a bucket named "Duchamp" for user "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "LoadData" - When click load data tab "Scrapers" - Then the scrapers tab is loaded - -@tested -Scenario: Exercise create Scraper popup - When click the create scraper button empty - Then the Create Scraper popup is loaded - When dismiss the Create Scraper popup - Then the Create Scraper popup is no longer present - When click the create scraper button from the header - Then the Create Scraper popup is loaded - When cancel the Create Scraper popup - Then the Create Scraper popup is no longer present - When click the create scraper button empty - Then the Create Scraper popup is loaded - When clear the Scraper Popup name input - Then the form element error message is "Name cannot be empty" - Then a form input error icon is shown - Then the Create Scrapper popup create button is disabled - When enter the name "Mumford" into the Create Scraper popup name input - Then the form element error message is not shown - Then no form input error icon is shown - Then the Create Scrapper popup create button is enabled - When click the Create Scrapper buckets dropdown - Then an item for the bucket "DEFAULT" is an item in the buckets dropdown - Then an item for the bucket "Duchamp" is an item in the buckets dropdown - When click the Create Scrapper buckets dropdown - Then NO items in the buckets dropdown are shown - When clear Scraper Popup the Target Url input - Then the form element error message is "Target URL cannot be empty" - Then a form input error icon is shown - Then the Create Scrapper popup create button is disabled - When enter the value "http://localhost:8086/metrics" into the Create Scraper popup url input - Then the form element error message is not shown - Then no form input error icon is shown - Then the Create Scrapper popup create button is enabled - When dismiss the Create Scraper popup - Then the Create Scraper popup is no longer present - -@tested -Scenario Outline: Create Scrapers - When click the create scraper button from the header - When clear the Scraper Popup name input - When enter the name "" into the Create Scraper popup name input - When click the Create Scrapper buckets dropdown - When select the Scrapper buckets dropdown item "" - When clear Scraper Popup the Target Url input - When enter the value "" into the Create Scraper popup url input - When click the create scraper create button - Then the success notification contains "Scraper was created successfully" - When close all notifications - Then the create scraper button empty is no longer present - Then there is a scraper card for "" - Then the scraper card named "" has the bucket "" - Then the scraper card named "" has the endpoint "" - - Examples: - | NAME | ENDPOINT | BUCKET | - | Melnik | http://localhost:8086/metrics | DEFAULT | - | Morlaix | http://localhost:8086/metrics | Duchamp | - | Brno | http://localhost:10018/bogus | DEFAULT | - | Brest | http://localhost:10018/bogus | Duchamp | - -@error-collateral -Scenario: Filter Scrapers - Then the scraper name sort order is "Brest,Brno,Melnik,Morlaix" - When enter the value "Br" into the scraper filter - Then the scraper name sort order is "Brest,Brno" - Then the scraper card "Melnik" is no longer present in the list - Then the scraper card "Morlaix" is no longer present in the list - When clear the scraper filter - Then the scraper name sort order is "Brest,Brno,Melnik,Morlaix" - -@error-collateral -Scenario: Sort Scrapers by Name - When click the sort type dropdown - When click sort by item "Name Desc" - #When click the scraper sort by name button - Then the scraper name sort order is "Morlaix,Melnik,Brno,Brest" - When click the sort type dropdown - When click sort by item "Name Asc" - #When click the scraper sort by name button - Then the scraper name sort order is "Brest,Brno,Melnik,Morlaix" - -@error-collateral -Scenario: Sort Scrapers by URL - When click the sort type dropdown - When click sort by item "URL Asc" - #When click the scraper sort By URL button - Then the scraper name sort order is "Brno,Brest,Melnik,Morlaix" - When click the sort type dropdown - When click sort by item "URL Desc" - #When click the scraper sort By URL button - Then the scraper name sort order is "Melnik,Morlaix,Brno,Brest" - -@error-collateral -Scenario: Sort Scrapers by Bucket - When click the sort type dropdown - When click sort by item "Bucket Asc" - #When click the scraper sort By Bucket button - Then the scraper name sort order is "Morlaix,Brest,Melnik,Brno" - When click the sort type dropdown - When click sort by item "Bucket Desc" - #When click the scraper sort By Bucket button - Then the scraper name sort order is "Melnik,Brno,Morlaix,Brest" - -@error-collateral -Scenario: Rename Scraper - When hover over the scraper card name "Brno" - When click the scraper card name edit control for the card "Brno" - When Enter the value "Plzeň" for the card "Brno" - Then the success notification contains "Scraper "Plzeň" was updated successfully" - Then there is a scraper card for "Plzeň" - Then the scraper card "Brno" is no longer present in the list - -@error-collateral -Scenario Outline: Verify Scraper data - Then the named query "" by user "" on the bucket "" contains the values "" - - Examples: - |USER|BUCKET|NAMED_QUERY|EXPECTED_VALUES| - |DEFAULT| Duchamp | Measurements | boltdb_reads_total,go_info,go_threads,influxdb_info,storage_reads_seeks | - |DEFAULT| DEFAULT | Measurements | boltdb_reads_total,go_info,go_threads,influxdb_info,storage_reads_seeks | - -@tested -Scenario Outline: Delete Scraper - Then the delete button of the scraper card named "" is not present - When hover over scraper card named "" - When click the delete button of the scraper card named "" - When click the confirm delete button of the scraper card named "" - Then the scraper card "" is no longer present in the list - - Examples: - | NAME | - | Melnik | - | Morlaix | - | Plzeň | - | Brest | diff --git a/e2e/features/loadData/telegrafs.feature b/e2e/features/loadData/telegrafs.feature deleted file mode 100644 index e7241813c5..0000000000 --- a/e2e/features/loadData/telegrafs.feature +++ /dev/null @@ -1,226 +0,0 @@ -@feature-loadData -@loadData-telegrafs -Feature: Load Data - Telegrafs - -Scenario: Load Initial Telegraf tab - Given I reset the environment - Given run setup over REST "DEFAULT" - When API sign in user "DEFAULT" - When API create a bucket named "Duchamp" for user "DEFAULT" - When API create a label "Cesko" described as "Pravda vitezi" with color "#AAFFAA" for user "DEFAULT" - When API create a label "Mesto" described as "Matka mest" with color "#FFAAAA" for user "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "LoadData" - When click load data tab "Telegrafs" - Then the telegrafs tab is loaded - -Scenario: Exercise create Telegraf wizard - When click the create Telegraf button empty - Then the Create Telegraf Wizard is loaded - When dismiss the Create Telegraf Wizard - Then the Create Telegraf Wizard is no longer present - When click the create Telegraf button in header - When click the select bucket dropdown in the Create Telegraf Wizard - When click the bucket item "DEFAULT" in the Create Telegraf Wizard - When enter the value "NGI" in create Telegraf Wizard filter plugins - Then the Create Telegraf wizard plugin tile "NGINX" is visible - Then the Create Telegraf wizard plugin tile "System" is not present - Then the Create Telegraf wizard plugin tile "Redis" is not present - Then the Create Telegraf wizard plugin tile "Docker" is not present - When clear the create Telegraf Wizard plugin filter - When click the plugin tile "System" in the Create Telegraf Wizard - When click the Popup Wizard continue button - Then the create Telegraf Wizard second step is loaded - Then the create Telegraf plugins sidebar contains "cpu,disk,diskio,mem,net,processes,swap,system" - Then the create Telegraf plugin sidebar "system" item is in state "success" - Then the create Telegraf plugin sidebar "cpu" item is in state "success" - Then the create Telegraf plugin sidebar "mem" item is in state "success" - When dismiss the Create Telegraf Wizard - Then the Create Telegraf Wizard is no longer present - When click the create Telegraf button empty - -Scenario Outline: Edit Plugin Values - When click the plugin tile "" in the Create Telegraf Wizard - When click the Popup Wizard continue button - Then the create Telegraf Wizard second step is loaded - Then the create Telegraf plugins sidebar contains "" - Then the create Telegraf plugin sidebar "" item is in state "neutral" - When click the create Telegraf plugin sidebar "" item - Then the create Telegraf edit plugin "" step is loaded - # When click the Popup Wizard done button - # Then the create Telegraf plugin sidebar "" item is in state "error" - # When click the create Telegraf plugin sidebar "" item - When enter the values into the fields - Then verify the edit plugin error notification with message "" - When clear the create Telegraf edit plugin fields - When enter the values into the fields - When click the Popup Wizard done button - Then the create Telegraf plugin sidebar "" item is in state "success" - When click the wizard previous button - Then the Create Telegraf Wizard is loaded - Then the Create Telegraf wizard plugin tile "" is selected - When click the plugin tile "" in the Create Telegraf Wizard - Then the Create Telegraf wizard plugin tile "" is not selected - Then the popup wizard continue button is disabled - - Examples: - | PLUGIN | FAKE_VALUES | FIELDS | ERRMSGS | TRUE_VALUES | - | Docker | SKIP | endpoint | SKIP | http://localhost:10080 | - | Kubernetes | ASDF | url | Must be a valid URI. | http://localhost:10080 | - | Redis | SKIP,SKIP | servers,password | SKIP | tcp://localhost:6379,wumpus | - -Scenario: Edit NGINX Plugin Values - When click the plugin tile "NGINX" in the Create Telegraf Wizard - When click the Popup Wizard continue button - Then the create Telegraf Wizard second step is loaded - Then the create Telegraf plugins sidebar contains "NGINX" - Then the create Telegraf plugin sidebar "NGINX" item is in state "neutral" - When click the create Telegraf plugin sidebar "NGINX" item - Then the create Telegraf edit plugin "NGINX" step is loaded - When enter the values ASDF into the fields urls - Then verify the edit plugin error notification with message "NONE" - When clear the create Telegraf edit plugin fields urls - When enter the values http://localhost:10080 into the fields urls - When click the NGINX configuration add button - Then the NGINX configuration URLs list contains "1" items - When click delete for the first NGINX configuration URL - When click confirm delete of NGINX configuration URL - Then the NGINX configuration URLs list is empty - When click the Popup Wizard done button - Then the create Telegraf plugin sidebar "NGINX" item is in state "error" - When click the create Telegraf plugin sidebar "NGINX" item - When enter the values http://localhost:10080 into the fields urls - When click the NGINX configuration add button - When click the Popup Wizard done button - Then the create Telegraf plugin sidebar "NGINX" item is in state "success" - When click the wizard previous button - Then the Create Telegraf Wizard is loaded - Then the Create Telegraf wizard plugin tile "NGINX" is selected - When click the plugin tile "NGINX" in the Create Telegraf Wizard - Then the Create Telegraf wizard plugin tile "NGINX" is not selected - Then the popup wizard continue button is disabled - -Scenario: Cleanup from Edit Plugin Values - When dismiss the Create Telegraf Wizard - -#N.B. just add UI artifacts - no need to check backend at this point -Scenario Outline: Create Telegraf - When click the create Telegraf button in header - When click the select bucket dropdown in the Create Telegraf Wizard - When click the bucket item "" in the Create Telegraf Wizard - When click the plugin tile "" in the Create Telegraf Wizard - When click the Popup Wizard continue button - When enter the name "" in the Create Telegraf Wizard - When enter the description "" in the Create Telegraf Wizard - When click the Popup Wizard continue button - Then the success notification contains "" - Then the success notification contains "Your configurations have been saved" - When close all notifications - Then the create Telegraf Wizard final step is loaded - When click the Create Telegraf Wizard finish button - Then there is a telegraf card for "" - Then the bucket of the telegraf card "" is "" - - - Examples: - | PLUGIN | BUCKET | NAME | DESCR | SUCCESS_MSG | - | System | DEFAULT |Strakonice | Lorem ipsum | Successfully created dashboards for telegraf plugin: system. | - | Docker | Duchamp |Decin | Lorem ipsum | SKIP | - | Kubernetes | DEFAULT |Kladno | Lorem ipsum | SKIP | - | NGINX | Duchamp |Nymburk | Lorem ipsum | SKIP | - | Redis | DEFAULT |Rakovnik | Lorem ipsum | SKIP | - -Scenario: Sort Telegrafs by Name - Then the telegraf sort order is "Decin,Kladno,Nymburk,Rakovnik,Strakonice" - When click the sort type dropdown - When click sort by item "Name Desc" - #When click the telegraf sort by name button - Then the telegraf sort order is "Strakonice,Rakovnik,Nymburk,Kladno,Decin" - When click the sort type dropdown - When click sort by item "Name Asc" - #When click the telegraf sort by name button - Then the telegraf sort order is "Decin,Kladno,Nymburk,Rakovnik,Strakonice" - -Scenario: Filter Telegrafs - When enter the value "Rak" into the Telegrafs filter - Then the telegraf sort order is "Rakovnik,Strakonice" - Then the telegraf cards "Decin,Kldano,Nymburk" are no longer present - When clear the Telegrafs filter - Then the telegraf sort order is "Decin,Kladno,Nymburk,Rakovnik,Strakonice" - -Scenario: Verify setup instructions - When click on setup instructions for the telegraf card "Decin" - Then the telegraf setup instruction popup is loaded - When dismiss the popup - Then popup is not loaded - -Scenario: Verify configuration - When click on the name of the telegraf card "Nymburk" - Then the telegraf configuration popup for "Nymburk" is loaded - When dismiss the popup - Then popup is not loaded - -Scenario: Edit Telegraf Card - When hover over the name of the telegraf card "Nymburk" - When click the name edit icon of the telegraf card "Nymburk" - When clear the name input of the telegraf card "Nymburk" - When set the name input of the telegraf card "Nymburk" to "Norimberk" - Then the Telegraf Card "Nymburk" can no longer be found - Then there is a telegraf card for "Norimberk" - When hover over the description of the telegraf Card "Norimberk" - When click the description edit icon of the telegraf card "Norimberk" - When clear the desrciption input of the telegraf card "Norimberk" - When set the description input of the telegraf card "Norimberk" to "Hunt the Wumpus" - Then the description of the telegraf card "Norimberk" is "Hunt the Wumpus" - - Scenario: Add labels to telegraf - Then the Label Popup for the Telegraf Card "Kladno" is not present - When click Add Label for Telegraf Card "Kladno" - Then the Label Popup for the Telegraf Card "Kladno" is visible - Then the item "Cesko" is in the Telegraf Card "Kladno" label select list - Then the item "Mesto" is in the Telegraf Card "Kladno" label select list - When filter the Telegraf Card "Kladno" label list with "Ce" - Then the item "Cesko" is in the Telegraf Card "Kladno" label select list - Then the item "Mesto" is NOT in the Telegraf Card "Kladno" label select list - When clear the label filter of the Telegraf Card "Kladno" - Then the item "Mesto" is in the Telegraf Card "Kladno" label select list - When click the item "Cesko" is in the Telegraf Card "Kladno" label select list - Then there is a label pill "Cesko" for the Telegraf Card "Kladno" - Then the item "Cesko" is NOT in the Telegraf Card "Kladno" label select list - When click the item "Mesto" is in the Telegraf Card "Kladno" label select list - Then there is a label pill "Mesto" for the Telegraf Card "Kladno" - Then the item "Mesto" is NOT in the Telegraf Card "Kladno" label select list - Then the label select list for "Kladno" shows the empty state message - When enter the value "Lidstvo" into the Telegraf Card "Kladno" label filter - Then the create Label popup is loaded - When dismiss the popup - Then popup is not loaded - - Scenario: Delete label from telegraf - When hover over the label pill "Cesko" for the Telegraf Card "Kladno" - When click delete the label pill "Cesko" for the Telegraf Card "Kladno" - Then the label pill "Cesko" for the Telegraf Card "Kladno" is NOT present - When click Add Label for Telegraf Card "Kladno" - # Affected by issue 16528 - Then the item "Cesko" is in the Telegraf Card "Kladno" label select list - # lose focus - When click telegraf card "Kladno" - Then the Label Popup for the Telegraf Card "Kladno" is not present - -Scenario Outline: Delete Telegraf Card - When hover over telegraf card "" - When click delete for telegraf card "" - When click delete confirm for telegraf card "" - Then the Telegraf Card "" can no longer be found - - Examples: - |NAME| - |Decin| - |Strakonice| - |Kladno | - |Norimberk | - |Rakovnik | - -# N.B. can verify telegrafs at endpoint http://localhost:8086/api/v2/telegrafs -# TODO - Test installation of telegraf and instructions - check back end diff --git a/e2e/features/loadData/tokens.feature b/e2e/features/loadData/tokens.feature deleted file mode 100644 index 783403a591..0000000000 --- a/e2e/features/loadData/tokens.feature +++ /dev/null @@ -1,183 +0,0 @@ -@feature-loadData -@loadData-tokens -Feature: Load Data - Tokens - -@tested - Scenario: Load Initial Tokens tab - Given I reset the environment - Given run setup over REST "DEFAULT" - When API sign in user "DEFAULT" - When API create a bucket named "Duchamp" for user "DEFAULT" - When API create a bucket named "Courbet" for user "DEFAULT" - When API create a bucket named "Corot" for user "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "LoadData" - When click load data tab "Tokens" - Then the tokens tab is loaded - Then the tokens list contains the token described as "admin's Token" - -@tested - Scenario: Exercise Create Read/Write Token Popup - When click the generate token dropdown - When click the generate token item "read-write" - Then the generate read-write token popup is loaded - When click the "Read" radio button "All Buckets" - Then the "Read" panel shows the empty state text - Then the bucket selector for the "Read" panel is not present - When click the "Write" radio button "All Buckets" - Then the "Write" panel shows the empty state text - Then the bucket selector for the "Write" panel is not present - When click the "Read" radio button "Scoped" - Then the "Read" panel empty state text is not present - Then the "Read" panel bucket selector is present - When click the "Write" radio button "Scoped" - Then the "Write" panel empty state text is not present - Then the "Write" panel bucket selector is present - Then the "Read" panel bucket list contains "DEFAULT,Corot,Courbet,Duchamp" - Then the "Write" panel bucket list contains "DEFAULT,Corot,Courbet,Duchamp" - When filter the "Read" panel bucket selector with "Co" - Then the "Read" panel bucket list contains "Corot,Courbet" - Then the "Read" panel bucket list does not contain "DEFAULT,Duchamp" - When clear the "Read" panel bucket selector - Then the "Read" panel bucket list contains "DEFAULT,Corot,Courbet,Duchamp" - When filter the "Write" panel bucket selector with "Co" - Then the "Write" panel bucket list contains "Corot,Courbet" - Then the "Write" panel bucket list does not contain "DEFAULT,Duchamp" - When clear the "Write" panel bucket selector - Then the "Write" panel bucket list contains "DEFAULT,Corot,Courbet,Duchamp" - When click "Read" panel select all buckets - Then the "Read" panel buckets "DEFAULT,Corot,Courbet,Duchamp" are selected - When click "Read" panel deselect all buckets - Then the "Read" panel buckets "DEFAULT,Corot,Courbet,Duchamp" are not selected - When click the "Read" panel bucket "Courbet" - Then the "Read" panel buckets "Courbet" are selected - Then the "Read" panel buckets "DEFAULT,Corot,Duchamp" are not selected - When click the "Read" panel bucket "Courbet" - Then the "Read" panel buckets "DEFAULT,Corot,Courbet,Duchamp" are not selected - When click "Write" panel select all buckets - Then the "Write" panel buckets "DEFAULT,Corot,Courbet,Duchamp" are selected - When click "Write" panel deselect all buckets - Then the "Write" panel buckets "DEFAULT,Corot,Courbet,Duchamp" are not selected - When click the "Write" panel bucket "Courbet" - Then the "Write" panel buckets "Courbet" are selected - Then the "Write" panel buckets "DEFAULT,Corot,Duchamp" are not selected - When click the "Write" panel bucket "Courbet" - Then the "Write" panel buckets "DEFAULT,Corot,Courbet,Duchamp" are not selected - When dismiss the popup - Then popup is not loaded - When click the generate token dropdown - When click the generate token item "read-write" - Then the generate read-write token popup is loaded - When click popup cancel button - Then popup is not loaded - -@error-collateral - Scenario: Exercise Create All Access Token Popup - When click the generate token dropdown - When click the generate token item "all-access" - Then the generate all-access token popup is loaded - When dismiss the popup - Then popup is not loaded - When click the generate token dropdown - When click the generate token item "all-access" - When click all-access token popup cancel - Then popup is not loaded - -@tested - Scenario Outline: Create Token - When click the generate token dropdown - When select token type based on type - When set token description for as - When set token privileges for as - When click popup save based on - Then the success notification contains "Token was created successfully" - When close all notifications - Then the tokens list contains the token described as "" - - Examples: - |DESCR|BUCKET|PRIVILEGES| - | Un enterrement a Ornans | Courbet | RW | - | Nu descendant un escalier | Duchamp | R | - | La Femme a la perle | Corot | RW | - | Dismaland | DEFAULT | R | - | Cambpells Soup | All | RW | - | La Jocande | ALL |ALL | - -@tested - Scenario Outline: Disable Token - When disable the token described as - Then the token described as is disabled - - Examples: - |DESCR| - | Dismaland | - | Nu descendant un escalier | - | Cambpells Soup | - - # Scenario: Sort By Status # not working see issue 15301 - -@error-collateral - Scenario: Sort By Name - Then the first tokens are sorted by description as "admin's Token, Campbells Soup, Dismaland, La Femme a la perle, La Jocande" - When click the tokens sorter button - When click the tokens sorter item "Description Asc" - Then the first tokens are sorted by description as "Un enterrement a Ornans, Nu descendant un escalier, La Jocande, La Femme a la perle, Dismaland" - When click the tokens sorter button - When click the tokens sorter item "Description Desc" - Then the first tokens are sorted by description as "admin's Token, Campbells Soup, Dismaland, La Femme a la perle, La Jocande" - -@error-collateral - Scenario: Edit Description - When hover over the token description "La Jocande" - When click the token description toggle for "La Jocande" - When clear the edit input for description "La Jocande" - When set the new description of "La Jocande" to "La Dame a l hermine" - Then the success notification contains "Token was updated successfully" - Then the tokens list contains the token described as "La Dame a l hermine" - Then the tokens list does not contain the token described as "La Jocande" - When close all notifications - -@tested - Scenario: Enable Token - When enable the token described as "Nu descendant un escalier" - Then the token described as "Nu descendant un escalier" is enabled - Then the success notification contains "Token was updated successfully" - When close all notifications - -@tested - Scenario Outline: Review Token - When click on the token described as "" - Then the review token popup is loaded - Then the review token popup matches "" and "" - When dismiss the popup - Then popup is not loaded - - Examples: - |DESCR|BUCKETS|PRIVILEGES| - | Un enterrement a Ornans | Courbet | read,write | - | Nu descendant un escalier | Duchamp | read | - | Cambpells Soup | All | read,write | - | La Dame a l hermine | ALL |ALL | - -@tested - Scenario Outline: Delete Token - When hover over token card described as "" - When click the delete button of the token card described as "" - When click delete confirm of the token card described as "" - #When click token card popover delete confirm - Then the success notification contains "Token was deleted successfully" - Then the tokens list does not contain the token described as "" - Then close all notifications - - Examples: - |DESCR| - | Un enterrement a Ornans | - | Nu descendant un escalier | - | La Femme a la perle | - | Dismaland | - | Cambpells Soup | - | La Dame a l hermine | - - - diff --git a/e2e/features/monitoring/alerts.feature b/e2e/features/monitoring/alerts.feature deleted file mode 100644 index 80630b641b..0000000000 --- a/e2e/features/monitoring/alerts.feature +++ /dev/null @@ -1,527 +0,0 @@ -@feature-monitoring -@monitoring-alerts -@use-live-data -Feature: Monitoring - Alerts - Base - As a user I want to setup alerts - So that I can be notified of important changes in the data - -@tested -Scenario: Load Initial Alerts view - Given I reset the environment - Given run setup over REST "DEFAULT" - #When hover over the "alerting" menu item - #When click nav sub menu "Monitoring & Alerting" - When API sign in user "DEFAULT" - When API create a label "Peano" described as "Theorie des ensembles" with color "#AAFFAA" for user "DEFAULT" - When API create a label "Euclide" described as "Geometrie euclidienne" with color "#FFAAAA" for user "DEFAULT" - When API create a label "Leibniz" described as "Calcul infinitésimal" with color "#AAAAFF" for user "DEFAULT" - When API create a label "Descartes" described as "Géométrie analytique" with color "#FFFFAA" for user "DEFAULT" - When start live data generator - # It seems 5s is the quickest we can use stably given default values in create check controls - # Tried 1s, but need to use agg function like mean so the checks do not seem to match - """ - { "pulse": 5000, "model": "count10" } - """ - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Alerting" - Then the Alerting page is loaded - When wait "10" seconds - -@tested -Scenario: Exercise Initial Alerts view Controls - Then the notification rules create dropdown is disabled - When click alerting tab "checks" - When click the create check button - Then the create check dropodown list contains the items - """ - threshold,deadman - """ - When click the create check button - Then the create check dropdown list is not visible - When hover the create check question mark - Then the create check tooltip is visible - When hover the alerts page title - Then the create check tooltip is not visible - When click alerting tab "endpoints" - When hover the create endpoint question mark - Then the create endpoint tooltip is visible - When hover the alerts page title - Then the create endpoint tooltip is not visible - When click alerting tab "rules" - When hover the create rule question mark - Then the create rules tooltip is visible - When hover the alerts page title - Then the create rules tooltip is not visible - When click alerting tab "endpoints" - When click create endpoint button - Then the create endpoint popup is loaded - When dismiss the popup - Then popup is not loaded - When click alerting tab "checks" - When click the first time create threshold check - Then the edit check overlay is loaded - When dismiss edit check overlay - Then the edit check overlay is not loaded - When click the first time create deadman check - Then the edit check overlay is loaded - When dismiss edit check overlay - Then the edit check overlay is not loaded - -# Create and start endpoint listener for notification checks - maybe move to separate endpoints test suite - -# Exercise Configure Check -- N.B. try and reuse dashboard time machine for Define Query -# TODO - Check illogical alert thresholds -# TODO - add simple tags check - -@tested - Scenario: Exercise Configure Check - Threshold - When click the create check button - When click the create check dropdown item "Threshold" - # Query Builder steps cover same library as in dashboards - TODO - check for gaps - # For now cover just configure check step - When click check editor configure check button - Then the configure check view is loaded - Then the create check checklist contains: - """ - [{ "state": "error", "text": "One field" }, - { "state": "valid", "text": "One aggregate function" }, - { "state": "error", "text": "One or more thresholds"}] - """ - Then the check interval hint dropdown list is not visible - When click on check interval input - Then the check interval hint dropdown list includes - """ - 5s,15s,1m,6h,24h,30d - """ - When click the interval hint dropdown list item "5m" - Then the check interval hint dropdown list is not visible - Then the interval indicator is set to "5m" - Then the check offset hint dropdown list is not visible - When click the check offset interval input - Then the check offset hint dropdown list includes - """ - 0s,5s,1m,1h,12h,2d - """ - When click the offset hint dropdown list item "1m" - Then the check offset hint dropdown list is not visible - Then the offset input is set to "1m" - When update the check message template to - """ - Kapela z Varsavy - """ - Then the check message tempate contains - """ - Kapela z Varsavy - """ - When click add threshold condition "CRIT" - When click the threshold definition dropdown for condition "CRIT" - # TODO - after issue 17729 is resolved - should be equal criteria e.g. n == 0 - Then the threshold definition dropdown for "CRIT" contain items: - """ - is above,is below,is inside range,is outside range - """ - When click the threshold definition dropodown item "Is Inside Range" for condition "CRIT" - Then there is a binary boundary for the threshold "CRIT" with values "20" and "100" - # N.B. currently cannot easily set negatve values - TODO use negative values once #17782 is resolved - # N.B. TODO - check dimensions of inputs - currently in smaller views they are unreadable #17783 - When set the binary boundary for the threshold "CRIT" from "0" to "1000" - Then there is a binary boundary for the threshold "CRIT" with values "0" and "1000" - When click add threshold condition "WARN" - When click the threshold definition dropdown for condition "WARN" - When click the threshold definition dropodown item "Is Below" for condition "WARN" - When set the unary boundary value for the threshold definition "WARN" to "0" - Then there is a unary boundary for the threshhold "WARN" with the value "0" - When dismiss edit check overlay - Then the first time create threshold check is visible - Then the first time create deadman check is visible - -@error-collateral - Scenario: Exercise configure check Deadman - # Just check Deadman fields others were covered in threshold test - When click the create check button - When click the create check dropdown item "Deadman" - When click check editor configure check button - Then the create check checklist contains: - """ - [{ "state": "error", "text": "One field" }] - """ - When click the deadman definition No Values For input - Then the deadman definition hints dropdown contains: - """ - 15s,5m,1h,12h,7d - """ - When click the deadman definition hint dropdown item "1m" - Then the deadman definition No Values For input contains "1m" - When set the value of the deadman definition No Values for input to "30m" - When click the deadman definition level dropdown - Then the deadman definition level dropdown contains: - """ - CRIT,WARN,INFO,OK - """ - When click the deadman definition level dropdown item "WARN" - Then the deadman definition level dropdown selected item is "WARN" - When click the deadman definition Stop Checking input - Then the deadman definition stop hints dropdown contains: - """ - 5s,1m,1h,24h,7d,30d - """ - When click the deadman definition stop hint dropdown item "5m" - Then the deadman definition stop input contains "5m" - When set the value of the definition stop input to "10m" - Then the deadman definition stop input contains "10m" - When dismiss edit check overlay - Then the first time create threshold check is visible - Then the first time create deadman check is visible - -# Create Threshold Alerts -@tested - Scenario: Create Simple Threshold Check - When click the first time create threshold check - Then the create check checklist contains: - """ - [{ "state": "error", "text": "One field" }, - { "state": "valid", "text": "One aggregate function" }, - { "state": "error", "text": "One or more thresholds"}] - """ - Then the save check button is disabled - When enter the alert check name "Simple Count Check" - When send keys "ENTER" - When click the tag "test" in builder card "1" - When click the tag "val" in builder card "2" - When click the query builder function "mean" - Then the create check checklist contains: - """ - [{ "state": "valid", "text": "One field" }, - { "state": "valid", "text": "One aggregate function" }, - { "state": "error", "text": "One or more thresholds"}] - """ - Then the save check button is disabled - # 7.8.20 -- feature disabled - see issue 19249 - # When click the time machine query builder function duration input - # When click the query builder function duration suggestion "5s" - When click the time machine cell edit submit button - Then the time machine cell edit preview graph is shown - When click check editor configure check button - Then the interval indicator is set to "1m" - Then the time machine cell edit preview graph is shown - When click the check offset interval input - When set the check interval input to "10s" - When enter into interval offset "1s" - When send keys "ENTER" - When update the check message template to - """ -${ r._check_name } is: ${ r._level } value was ${string(v: r.val)} - """ - When click add threshold condition "CRIT" - When click the threshold definition dropdown for condition "CRIT" - When click the threshold definition dropodown item "Is Above" for condition "CRIT" - When set the unary boundary value for the threshold definition "CRIT" to "7.5" - Then the create check checklist is not present - Then the save check button is enabled - Then the time machine cell edit preview contains threshold markers: - """ - CRIT - """ - When click the check editor save button - Then there is an alert card named "Simple Count Check" - - # Create Deadman Alerts -@error-collateral - Scenario: Create simple Critical Deadman Check - # Just check Deadman fields others were covered in threshold test - When click the create check button - When click the create check dropdown item "Deadman" - When enter the alert check name "Deadman Critical Check" - When click the tag "test" in builder card "1" - When click the tag "val" in builder card "2" - When click the time machine cell edit submit button - Then the time machine cell edit preview graph is shown - When click check editor configure check button - When set the check interval input to "10s" - When set the check offset interval input "2s" - When click the edit check add tag button - When set the check tag key of tag "1" to "mrtvola" - When set the check tag value of tag "1" to "neboztik" - When click the edit check add tag button - When set the check tag key of tag "2" to "kartoffel" - When set the check tag value of tag "2" to "brambor" - When update the check message template to - """ -${ r._check_name } is: ${ r._level } value [${string(v: r.val)}] has stopped reporting - """ - When set the value of the deadman definition No Values for input to "30s" - When set the value of the definition stop input to "2m" - When click the check editor save button - Then there is an alert card named "Deadman Critical Check" - - # Need second card for filter and sort tests -@error-collateral - Scenario: Create simple Warn Deadman Check - # Just check Deadman fields others were covered in threshold test - When click the create check button - When click the create check dropdown item "Deadman" - When enter the alert check name "Deadman Warn Check" - When click the tag "test" in builder card "1" - When click the tag "val" in builder card "2" - When click the time machine cell edit submit button - Then the time machine cell edit preview graph is shown - When click check editor configure check button - When set the check interval input to "10s" - When set the check offset interval input "2s" - When click the edit check add tag button - When update the check message template to - """ -${ r._check_name } is: ${ r._level } has stopped reporting. Last value [${string(v: r.val)}] - """ - When set the value of the deadman definition No Values for input to "20s" - When set the value of the definition stop input to "1m" - When click the check editor save button - Then the error notification contains "Failed to create check: tag must contain a key and a value" - When close all notifications - When remove check tag key "1" - When click the check editor save button - Then there is an alert card named "Deadman Warn Check" - -# TODO - EDIT Threshold Check and drag threshold control in graph - -# Edit Check Card -@error-collateral -Scenario: Edit Check Card - When hover over the name of the check card "Deadman Warn Check" - When click the name edit button of the check card "Deadman Warn Check" - When update the active check card name input to "Veille automatique - Avertissement" - When send keys "ENTER" - Then there is an alert card named "Veille automatique - Avertissement" - When hover over the description of the check card "Veille automatique - Avertissement" - When click the description edit button of the check card "Veille automatique - Avertissement" - When update the active check card description input to: - """ -Que ta voix, chat mystérieux, Chat séraphique, chat étrange... Baudelaire - """ - When send keys "ENTER" - Then the check card "Veille automatique - Avertissement" contains the description: - """ -Que ta voix, chat mystérieux, Chat séraphique, chat étrange... Baudelaire - """ - -# Add labels to checks -@tested -Scenario: Add Labels To Checks - When click empty label for check card "Deadman Critical Check" - Then the add label popover is present - # dismiss popover - # TODO - once #17853 is fixed - use ESC key to dismiss popover - When click the checks filter input - Then the add label popover is not present - When click the add labels button for check card "Deadman Critical Check" - Then the add label popover is present - Then the add label popover contains the labels - """ - Peano,Euclide,Leibniz,Descartes - """ - When click the label popover item "Peano" - When click the label popover item "Leibniz" - Then the add label popover contains the labels - """ - Euclide,Descartes - """ - Then the add label popover does not contain the labels: - """ - Peano,Leibniz - """ - When set the label popover filter field to "Godel" - Then the add label popover does not contain the labels: - """ - Euclide,Descartes - """ - Then the label popover contains create new "Godel" - When clear the popover label selector filter - Then the add label popover contains the labels - """ - Euclide,Descartes - """ - Then the add label popover does not contain the labels: - """ - Peano,Leibniz - """ - Then the add label popover does not contain create new - # TODO - use escape to close popover once #17853 is resolved - When click the checks filter input - Then the add label popover is not present - Then the check card "Deadman Critical Check" contains the label pills: - """ - Peano,Leibniz - """ - When remove the label pill "Peano" from the check card "Deadman Critical Check" - Then the check card "Deadman Critical Check" contains the label pills: - """ - Leibniz - """ - Then the check card "Deadman Critical Check" does not contain the label pills: - """ - Peano - """ - When click the add labels button for check card "Deadman Critical Check" - Then the add label popover contains the labels - """ - Peano,Euclide,Descartes - """ - # TODO - use escape to close popover once #17853 is resolved - When click the checks filter input - -# Clone check -@error-collateral - Scenario: Clone Check - When hover over the name of the check card "Simple Count Check" - # When wait "1" seconds - When click the check card "Simple Count Check" clone button - When click the check card "Simple Count Check" clone confirm button - Then there is an alert card named "Simple Count Check (clone 1)" - When click the check card name "Simple Count Check (clone 1)" - Then the edit check overlay is loaded - Then the current edit check name is "Simple Count Check (clone 1)" - Then the interval indicator is set to "10s" - Then the offset input is set to "1s" - Then the check message tempate contains - """ -${ r._check_name } is: ${ r._level } value was ${string(v: r.val)} - """ - Then there is a unary boundary for the threshhold "CRIT" with the value "7.5" - When click checkeditor define query button - Then there are "3" time machine builder cards - Then time machine builder card "1" contains: - """ - test - """ - Then time machine builder card "2" contains: - """ - val - """ - Then the item "test" in builder card "1" is selected - Then the item "val" in builder card "2" is selected - # TODO - verify Bucket Card contents after #17879 fixed - When enter the alert check name "Bécik" - When click the check editor save button - Then there is an alert card named "Bécik" - -# Filter Checks -@error-collateral - Scenario: Filter Checks - Then the check cards column contains - """ - Simple Count Check, Deadman Critical Check, Veille automatique - Avertissement, Bécik - """ - When enter into the check cards filter field "Check" - Then the check cards column contains - """ - Simple Count Check, Deadman Critical Check - """ - Then the check cards column does not contain - """ - Veille automatique - Avertissement, Bécik - """ - When enter into the check cards filter field "Be" - Then the "checks" cards column empty state message is "No checks match your search" - When enter into the check cards filter field "Bé" - Then the check cards column contains - """ - Bécik - """ - Then the check cards column does not contain - """ - Simple Count Check, Deadman Critical Check - """ - When clear the check cards filter field - Then the check cards column contains - """ - Simple Count Check, Deadman Critical Check, Veille automatique - Avertissement, Bécik - """ - - Scenario: Threshold Check history - basic - When hover over the name of the check card "Simple Count Check" - # Collect some data - generate at least 1 event - When wait "10" seconds - When click open history of the check card "Simple Count Check" - When click open history confirm of the check card "Simple Count Check" - # Just check page load - # Check history will be separate test feature - Then the Check statusses page is loaded - Then there are at least "1" events in the history - Then event no "1" contains the check name "Simple Count Check" - When click the check name of event no "1" - Then the edit check overlay is loaded - Then the current edit check name is "Simple Count Check" - When dismiss edit check overlay - Then the edit check overlay is not loaded - Then the Alerting page is loaded - Then there is an alert card named "Simple Count Check" - - Scenario: Deadman Check history - basic - When stop live data generator - When wait "60" seconds - When hover over the name of the check card "Deadman Critical Check" - When click open history of the check card "Deadman Critical Check" - When click open history confirm of the check card "Deadman Critical Check" - Then the Check statusses page is loaded - Then there are at least "1" events in the history - Then event no "1" contains the check name "Deadman Critical Check" - Then there is at least "1" events at level "crit" - When click the check name of event no "1" - Then the edit check overlay is loaded - Then the current edit check name is "Deadman Critical Check" - When dismiss edit check overlay - Then the edit check overlay is not loaded - Then the Alerting page is loaded - Then there is an alert card named "Deadman Critical Check" - When start live data generator - # restart live generator as above - """ - { "pulse": 5000, "model": "count10" } - """ - -# Delete Check - Scenario Template: Delete Check - When hover over the name of the check card "" - When click delete of the check card "" - When click delete confirm of the check card "" - Then there is no alert card named "" - Examples: - |NAME| - |Bécik| - |Veille automatique - Avertissement| - |Deadman Critical Check| - |Simple Count Check| - - -# TODO - Edit Check definition - -# Edit Check definition - -# Create Endpoints {HTTP, Slack, Pager Duty} - -# Add labels to Endpoints - -# Filter Endpoints - -# Edit Endppints - -# Create Rules - -# Add labels to Rules - -# Filter Rules - -# Edit Rules - -# Delete Checks (N.B. what is affect on dependent rules?) - -# Delete Endpoints (N.B. what is affect on dependent rules?) - -# Delete Rules - -# Tear down data generator - In After All hook - needs to be torn down after failure as well as success - -# Tear down http listened - In After All hook - ditto - -# NOTE - perhaps should have five features - base, checks, endpoints, rules, full monitoring (too harvest alerts -# and notifications.) - breakup planned tests above into these feature files. diff --git a/e2e/features/monitoring/history.feature b/e2e/features/monitoring/history.feature deleted file mode 100644 index 162cb8e9ee..0000000000 --- a/e2e/features/monitoring/history.feature +++ /dev/null @@ -1,59 +0,0 @@ -@feature-monitoring -@monitoring-alerts -@use-live-data -Feature: Monitoring - Alerts - History - As a user I want to setup alerts - So that I can be notified of important changes in the data - - Scenario: Load Initial Alerts view - Given I reset the environment - Given run setup over REST "DEFAULT" - When API sign in user "DEFAULT" - When start live data generator - # It seems 5s is the quickest we can use stably given default values in create check controls - # Tried 1s, but need to use agg function like mean so the checks do not seem to match - """ - { "pulse": 5000, "model": "count10" } - """ - When wait "10" seconds - When create check over API from file "etc/test-data/test_threshold_check.json" for user "DEFAULT" - When create check over API from file "etc/test-data/test_deadman_crit_check.json" for user "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Alerting" - Then the Alerting page is loaded - # Need to create events for toggle markers - When wait "60" seconds - -# Exercise controls - Scenario: Exercise Event History Controls - When hover over the name of the check card "Threshold Check from File" - When click open history of the check card "Threshold Check from File" - When click open history confirm of the check card "Threshold Check from File" - When click event history filter input - Then the event history examples dropdown is visible - When click the alert history title - Then the event history examples dropdown is not visible - - When get events history graph area - When get event marker types and locations - When zoom into event markers - Then the event marker locations have changed - Then the events history graph has changed - Then the event toggle "OK" is off - Then the event toggle "CRIT" is on - When get events history graph area - When get event marker types and locations - #Unzoom - When double click history graph area - Then the event marker locations have changed - Then the events history graph has changed - Then the event toggle "OK" is off - Then the event toggle "CRIT" is on - -# Toggle markers - #incl. hover bars and heads - -# Filter - N.B. clear filter shows all checks - - diff --git a/e2e/features/onboarding/onboarding.feature b/e2e/features/onboarding/onboarding.feature deleted file mode 100644 index 94ae7435f3..0000000000 --- a/e2e/features/onboarding/onboarding.feature +++ /dev/null @@ -1,84 +0,0 @@ -@feature-onboarding -@onboarding-onboarding -Feature: Onboard to Influxdbv2 - Create an initial user and organization - -@tested - Scenario: Onboard Basic -# Golden path check 1 - Given I reset the environment - Given I open the Influx onboarding page - Then there is a Welcome message - Then there is a link to corporate - When I click on Get Started - Then the Initial Setup Page is loaded - When enter a new user name "DEFAULT" - When enter a new password "DEFAULT" - When enter confirm the new password "DEFAULT" - When enter a new organization name "DEFAULT" - When enter a new bucket name "DEFAULT" - When click next from setup page - Then verify ready page - Then the success notification says "Initial user details have been successfully set" - When click quick start button - Then the success notification contains "Metrics Dashboard has been created" - Then the success notification contains "The InfluxDB Scraper has been configured" - When close all notifications - Then the home page is loaded - -@tested - Scenario: Onboard Advanced -# Golden path check 2 - Given I reset the environment - Given I open the Influx onboarding page - Then there is a Welcome message - Then there is a link to corporate - When I click on Get Started - Then the Initial Setup Page is loaded - When enter a new user name "DEFAULT" - When enter a new password "DEFAULT" - When enter confirm the new password "DEFAULT" - When enter a new organization name "DEFAULT" - When enter a new bucket name "DEFAULT" - When click next from setup page - Then verify ready page - Then the success notification says "Initial user details have been successfully set" - When close all notifications - When click advanced button - Then the buckets tab is loaded - -@tested - Scenario: Onboard field checks -# N.B. would expect there to be rules for min/max length or allowed/disallowed characters in user-names -# however none currently exist -- TODO add tests for such rules if they are ever implemented - # TODO - setup breadcrumb color change on password length less than 8 chars - Given I reset the environment - Given I open the Influx onboarding page - Then there is a Welcome message - Then there is a link to corporate - When I click on Get Started - Then the Initial Setup Page is loaded - Then the continue button is disabled - When enter a new user name "zaphod" - When enter a new password "chachacha" - When enter confirm the new password "achachach" - Then the form error message says "Passwords do not match" - When enter confirm the new password "chachacha" - Then the form error message is not present - When enter a new organization name "asdf" - When enter a new bucket name "asdf" - When enter a new password "asdf" - When enter confirm the new password "asdf" - Then the form error message says "Password must be at least 8 characters" - Then the continue button is disabled - When enter a new password "chachacha" - When enter confirm the new password "chachacha" - When click next from setup page - Then verify ready page - Then the success notification says "Initial user details have been successfully set" - When click quick start button - Then the success notification contains "Metrics Dashboard has been created" - Then the success notification contains "The InfluxDB Scraper has been configured" - When close all notifications - Then the home page is loaded - diff --git a/e2e/features/settings/labels.feature b/e2e/features/settings/labels.feature deleted file mode 100644 index 9f7c143c5e..0000000000 --- a/e2e/features/settings/labels.feature +++ /dev/null @@ -1,152 +0,0 @@ -@feature-settings -@settings-labels -Feature: Settings - Labels - As a user I want to Read Create Update and Delete Labels - So that I can manage the tag items used with Influxdbv2 - -@tested -Scenario: Open Labels Tab - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Settings" - When click the settings tab "Labels" - Then the labels Tab is loaded - -@tested -Scenario: Exercise Create Label Popup - When I click the empty state Create Label button - Then the create Label popup is loaded - When dismiss the popup - Then popup is not loaded - When I click the header Create Label button - Then the create Label popup is loaded - When cancel the create label popup - Then popup is not loaded - When I click the header Create Label button - Then the color input color matches the preview color - Then the preview label pill contains "Name this Label" - When enter the value "Etiketa" into the label popup name input - Then the preview label pill contains "Etiketa" - When clear the label popup color input - Then the form element error message is "Please enter a hexcode" - When enter the value "#" into the label popup color input - Then the form element error message is "Must be 7 characters" - When clear the label popup color input - When enter the value "#FFC0CB" into the label popup color input - Then the color input color matches the preview color - When click the color select button I'm feeling lucky - Then the value in the label popup color input is not "#FFC0CB" - Then the color input color matches the preview color - When click the label popup color swatch "Ruby" - Then the value in the label popup color input is "#BF3D5E" - Then the color input color matches the preview color - Then the label popup preview text color is "#FFFFFF" - When click the label popup color swatch "Onyx" - Then the value in the label popup color input is "#31313d" - Then the color input color matches the preview color - Then the label popup preview text color is "#FFFFFF" - When click the label popup color swatch "Laser" - Then the value in the label popup color input is "#00C9FF" - Then the color input color matches the preview color - Then the label popup preview text color is "#202028" - When dismiss the popup - Then popup is not loaded - -@tested -Scenario Outline: Create Label - When I click the header Create Label button - When clear the label popup name input - When enter the value "" into the label popup name input - When clear the label popup description input - When enter the value "" into the label popup description input - When set the color in the label popup to "" - When click the label popup Create Label button - Then there is a label card named "" in the labels list - Then the label card "" has a pill colored "" - Then the label card "" has description "" - - Examples: - | NAME | DESCRIPTION | COLOR | - | Buk | Fagus sylvatica | Topaz | - | Habr | Carpinus betulus | #D2691E | - | Jilm | Ulmus laevis | Thunder | - | Javor | Acer pseudoplatanus | #924544 | - | Bouleau | Betula verrucosa | #F5EAD5 | - -@tested -Scenario: Edit Label - When I click the Label Card Pill "Bouleau" - Then the edit label popup is loaded - When clear the label popup name input - When enter the value "Briza" into the label popup name input - When clear the label popup description input - When enter the value "Betula pendula" into the label popup description input - When set the color in the label popup to "#ECFC31" - Then the color input color matches the preview color - When click the label popup Save Changes button - Then there is a label card named "Briza" in the labels list - Then the label card "Briza" has a pill colored "#ECFC31" - Then the label card "Briza" has description "Betula pendula" - -@tested -Scenario: Sort By Name - Then the first labels are sorted as "Briza,Buk,Habr,Javor,Jilm" - When click the sort type dropdown - When click sort by item "Name Desc" - Then the first labels are sorted as "Jilm,Javor,Habr,Buk,Briza" - When click the sort type dropdown - When click sort by item "Name Asc" - Then the first labels are sorted as "Briza,Buk,Habr,Javor,Jilm" - -@error-collateral -Scenario: Sort By Description - When click the sort type dropdown - When click sort by item "Properties.Description Asc" - #When click sort label by description - Then the first labels are sorted as "Javor,Briza,Habr,Buk,Jilm" - When click the sort type dropdown - When click sort by item "Properties.Description Desc" - #When click sort label by description - Then the first labels are sorted as "Jilm,Buk,Habr,Briza,Javor" - - -@tested - Scenario: Filter Labels - When clear the labels filter input - When enter the value "J" into the label filter - Then the first labels are sorted as "Jilm,Javor" - Then the labels "Briza,Buk,Habr" are not present - When enter the value "AV" into the label filter - Then the first labels are sorted as "Javor" - Then the labels "Briza,Buk,Habr,Jilm" are not present - When clear the labels filter input - When enter the value "betul" into the label filter - Then the first labels are sorted as "Habr,Briza" - Then the labels "Buk,Javor,Jilm" are not present - When click the sort type dropdown - When click sort by item "Name Desc" - # There is a third neutral phase to the toggle - not anymore - #When click sort label by name - Then the first labels are sorted as "Habr,Briza" - When click the sort type dropdown - When click sort by item "Name Asc" - Then the first labels are sorted as "Briza,Habr" - When clear the labels filter input - Then the first labels are sorted as "Briza,Buk,Habr,Javor,Jilm" - -@tested -Scenario Outline: Delete Label - When hover over label card "" - When click delete for the label card "" - When click delete confirm for the label card "" - Then the labels "" are not present - - Examples: - | NAME | - | Briza | - | Buk | - | Habr | - | Javor | - | Jilm | diff --git a/e2e/features/settings/settings.feature b/e2e/features/settings/settings.feature deleted file mode 100644 index 53bc9edaa6..0000000000 --- a/e2e/features/settings/settings.feature +++ /dev/null @@ -1,27 +0,0 @@ -@feature-settings -@settings-settings -Feature: Settings - Base - As a user I want to open the settings page - So that I can explore how this Influx2 installation is set up - -# TODO with alerting / load data refactor now submenu is richer - - Scenario: Verify Tabs - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When open page "settings" for user "DEFAULT" - When click the settings tab "Variables" - Then the variables Tab is loaded - When click the settings tab "Templates" - Then the templates Tab is loaded - When click the settings tab "Labels" - Then the labels Tab is loaded -# When click the settings tab "Tokens" # Tokens tab is no longer available -# Then the tokens Tab is loaded # Tokens tab is no longer available - # The following items are no longer present commit=bd91a81123 build_date=2020-04-07T07:57:22Z -# When click the settings tab "Profile" -# Then the org profile Tab is loaded -# When click the settings tab "Members" -# Then the members Tab is loaded diff --git a/e2e/features/settings/templates.feature b/e2e/features/settings/templates.feature deleted file mode 100644 index 4e04e4669b..0000000000 --- a/e2e/features/settings/templates.feature +++ /dev/null @@ -1,168 +0,0 @@ -@feature-settings -@settings-templates -Feature: Settings - Templates - As a user I want to Read Create Update and Delete Templatess - So that I can eventually use them to create dashboards in Influxdbv2 - -@tested - Scenario: Open Templates Tab - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When UI sign in user "DEFAULT" - When click nav menu item "Settings" - When click the settings tab "Templates" - Then the templates Tab is loaded - Then the templates are sorted as: - """ - Apache Data,Docker,Getting Started with Flux,GitHub Data,InfluxDB 2.0 OSS Metrics,JMeter,Kubernetes,Nginx,Redis,System - """ - When API sign in user "DEFAULT" - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 120, "measurement":"level", "start": "-30d", "algo": "hydro", "prec": "sec", "name": "hydro"} - """ - When generate a line protocol testdata for user "DEFAULT" based on: - """ - { "points": 120, "measurement":"beat", "start": "-30d", "algo": "sine", "prec": "sec", "name": "sine"} - """ - - -@tested - Scenario: Exercise Import Template Popup - When click user templates - When click empty state import template button - Then the import template popup is loaded - Then the Import JSON as template button is disabled - When dismiss the popup - Then popup is not loaded - When click header import template button - Then click the import template paste button - Then the Import Template file upload area is not present - Then the Import Template paste JSON text area is present - When enter into the Impprt Template paste JSON text area: - """ - {} - """ - Then the Import JSON as template button is enabled - When click the import template upload button - Then the Import JSON as template button is disabled - Then the Import Template file upload area is present - Then the Import Template paste JSON text area is not present - When dismiss the popup - Then popup is not loaded - -# TODO add variables to templates - -@error-collateral - Scenario Outline: Import User Template File Upload - When click user templates - When click header import template button - When upload the template file "" - When click import template popup submit button - Then popup is not loaded - Then the success notification contains "Successfully imported template." - When close all notifications - # sometimes page is stuck in cache - When force page refresh - When wait "10" seconds - Then a REST template document for user "DEFAULT" titled "" exists - # Following step is work around for issue 15514 - When click user templates - Then there is a template card named "<TITLE>" - - Examples: - |TITLE|FILEPATH| - |Hydro test dashboard-Template|etc/test-data/hydro-test-template.json| - |Note Dashboard-Template|etc/test-data/note-dboard-template.json| - -@error-collateral - Scenario Outline: Import User Template as JSON - When click header import template button - Then click the import template paste button - When paste contents of "<FILEPATH>" to template textarea - When click import template popup submit button - Then popup is not loaded - Then the success notification contains "Successfully imported template." - When close all notifications - # sometimes page is stuck in cache - When force page refresh - When wait "10" seconds - Then a REST template document for user "DEFAULT" titled "<TITLE>" exists - # Following step is work around for issue 15514 - When click user templates - Then there is a template card named "<TITLE>" - - Examples: - |TITLE|FILEPATH| - |Sinusoid test data-Template|etc/test-data/sine-test-template.json| - |Notepad-Template|etc/test-data/notepad-test-template.json| - -@error-collateral - Scenario: Import Bad Template File - When click user templates - When click header import template button - When upload the template file "etc/test-data/bad-template.json" - When click import template popup submit button - Then popup is not loaded - Then the error notification contains "Failed to import template: Error: Request failed with status code 400" - When close all notifications - -@error-collateral - Scenario: Filter Templates - When click user templates - When enter the value "Note" into the templates filter field - Then the templates are sorted as: - """ - Note Dashboard-Template,Notepad-Template - """ - Then the template cards "Hydro test dashboard-Template,Sinusoid test data-Template" are not present - When clear the templates filter - Then the templates are sorted as: - """ - Hydro test dashboard-Template,Note Dashboard-Template,Notepad-Template,Sinusoid test data-Template - """ - -@error-collateral - Scenario: Sort Templates by Name - When click the sort type dropdown - When click sort by item "Meta.Name Desc" - Then the templates are sorted as: - """ - Sinusoid test data-Template,Notepad-Template,Note Dashboard-Template,Hydro test dashboard-Template - """ - When click the sort type dropdown - When click sort by item "Meta.Name Asc" - Then the templates are sorted as: - """ - Hydro test dashboard-Template,Note Dashboard-Template,Notepad-Template,Sinusoid test data-Template - """ - - #Scenario: Exercise View Template Popup - # TODO - this part of UI was being rewritten - - #Scenario: Clone Template - # TODO - this part of UI was being rewritten - - #Scenario: Rename Template - # TODO - this part of UI was being rewritten - - # N.B. generate some labels above - to be used in this test - # Scenario: Add Labels to Template - # Issue #15547 - create new label through templates runs into this minor issue - - # Scenario: Create Dashboard from Template - # Covered in Dashboard tests - -@error-collateral - Scenario Outline: Delete template - When hover over template card named "<NAME>" - When click the context delete button of template "<NAME>" - When click the delete confirm button of template "<NAME>" - Then the template cards "<NAME>" are not present - Examples: - |NAME| - |Hydro test dashboard-Template| - |Note Dashboard-Template | - |Notepad-Template | - |Sinusoid test data-Template | diff --git a/e2e/features/settings/variables.feature b/e2e/features/settings/variables.feature deleted file mode 100644 index 2d34c9921c..0000000000 --- a/e2e/features/settings/variables.feature +++ /dev/null @@ -1,349 +0,0 @@ -@feature-settings -@settings-variables -Feature: Settings - Variables - As a user I want to Read Create Update and Delete Variables - So that I can eventually reuse them in alerts and dashboards in Influxdbv2 - - Scenario: Open Variables Tab - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When clear browser storage - When UI sign in user "DEFAULT" - When click nav menu item "Settings" - When click the settings tab "Variables" - Then the variables Tab is loaded - - Scenario: Exercise Import Variable Popup - When click create variable dropdown in header - When click "import" variable dropdown item - Then the import variable popup is loaded - Then dismiss the popup - Then popup is not loaded - When click create variable dropdown empty - When click "import" variable dropdown item - Then the import variable popup is loaded - When click the Import Variable popup paste JSON button - Then the Import Variable JSON textarea is visible - Then the Import JSON as variable button is enabled - When click the Import Variable popup Upload File button - Then the Import Variable JSON textarea is not visible - Then the Import JSON as variable button is not enabled - Then the Import JSON file upload area is present - Then dismiss the popup - Then popup is not loaded - -@tested - Scenario: Exercise Create Variable Popup - When click create variable dropdown in header - When click "new" variable dropdown item - Then the create variable popup is loaded - Then dismiss the popup - Then popup is not loaded - When click create variable dropdown empty - When click "new" variable dropdown item - Then the create variable popup is loaded - Then the create variable popup selected type is "Query" - Then the create variable popup create button is disabled - Then the create variable popup script editor is visible - When click the create variable popup type dropdown - When click the create variable popup type dropdown item "Map" - Then the create variable popup selected type is "Map" - Then the create variable popup create button is disabled - Then the create variable popup script editor is not visible - Then the create variable popup textarea is visible - Then the create variable popup default value dropdown is visible - Then the create variable popup info line contains "0" items - When click the create variable popup type dropdown - When click the create variable popup type dropdown item "constant" - Then the create variable popup selected type is "CSV" - Then the create variable popup create button is disabled - Then the create variable popup script editor is not visible - Then the create variable popup textarea is visible - Then the create variable popup default value dropdown is visible - Then the create variable popup info line contains "0" items - When click the create variable popup type dropdown - When click the create variable popup type dropdown item "Query" - Then the create variable popup selected type is "Query" - Then the create variable popup create button is disabled - Then the create variable popup script editor is visible - Then the create variable popup textarea is not visible - Then the create variable popup default value dropdown is not visible - Then the create variable popup info line is not visible - Then click popup cancel simple button - Then popup is not loaded - - Scenario Outline: Import Variable - When click create variable dropdown in header - When click "import" variable dropdown item - When upload the import variable file "<FILE>" - Then the import variable drag and drop header contains success "<FILE>" - When click the import variable import button - Then popup is not loaded - Then the success notification contains "Successfully created new variable: <NAME>" - Then close all notifications - Then there is a variable card for "<NAME>" - - Examples: - |NAME|FILE| - |Bucket|etc/test-data/variable-query-bucket.json| - |Ryby|etc/test-data/variable-map-ryby.json| - |Jehlicnany|etc/test-data/variable-map-jehlicnany.json| - |Slavia|etc/test-data/variable-csv-slavia.json| - |Arsenal|etc/test-data/variable-csv-arsenal.json| - - - # TODO - failover on bad variable file -@tested - Scenario: Import Bad Variable - When click create variable dropdown in header - When click "import" variable dropdown item - When upload the import variable file "etc/test-data/variable-empty.json" - Then the import variable drag and drop header contains success "etc/test-data/variable-empty.json" - When click the import variable import button - Then popup is not loaded - Then the error notification contains "Failed to create variable:" - Then close all notifications - - Scenario: Create Map Variable - When click create variable dropdown in header - When click "new" variable dropdown item - When click the create variable popup type dropdown - When click the create variable popup type dropdown item "map" - When clear the create variable popup name input - When enter the create variable popup name "Primaty" - When enter the create variable popup values: - """ - Human,homo sapiens - Orangutan,pongo - Chimpanzee,pan troglodytes - Gorilla,gorilla - Baboon,papio - """ - When click the create variable popup title - Then the create variable popup info line contains "5" items - Then the selected default variable dropdown item is "Human" - When click the create variable popup default dropdown - When click the create variable popup default dropdown item "Chimpanzee" - Then the selected default variable dropdown item is "Chimpanzee" - When click the create variable popup create button - Then popup is not loaded - Then the success notification contains "Successfully created new variable: Primaty" - Then close all notifications - Then there is a variable card for "Primaty" - - Scenario: Create CSV Variable - When click create variable dropdown in header - When click "new" variable dropdown item - When click the create variable popup type dropdown - When click the create variable popup type dropdown item "constant" - When clear the create variable popup name input - When enter the create variable popup name "Obdobi" - When enter the create variable popup values: - """ - Antropocen,Holocen,Svrchni pleistocen,Stredni pleistocen,Spodni pleistocen - """ - When click the create variable popup title - Then the create variable popup info line contains "5" items - Then the selected default variable dropdown item is "Antropocen" - When click the create variable popup default dropdown - When click the create variable popup default csv dropdown item "Holocen" - Then the selected default variable dropdown item is "Holocen" - When click the create variable popup create button - Then popup is not loaded - Then the success notification contains "Successfully created new variable: Obdobi" - Then close all notifications - Then there is a variable card for "Obdobi" - - Scenario: Create CSV Variable - When click create variable dropdown in header - When click "new" variable dropdown item - When click the create variable popup type dropdown - When click the create variable popup type dropdown item "constant" - When clear the create variable popup name input - When enter the create variable popup name "Reals" - When enter the create variable popup values: - """ - 1.0,2.0,2.72,3.0,3.14 - """ - When click the create variable popup title - Then the create variable popup info line contains "5" items - Then the selected default variable dropdown item is "1.0" - When click the create variable popup default dropdown - When click the create variable popup default csv dropdown item "2.0" - Then the selected default variable dropdown item is "2.0" - When click the create variable popup create button - Then popup is not loaded - Then the success notification contains "Successfully created new variable: Reals" - Then close all notifications - Then there is a variable card for "Reals" - - - Scenario: Create Query Variable - When click create variable dropdown in header - When click "new" variable dropdown item - When click the create variable popup type dropdown - When click the create variable popup type dropdown item "Query" - When clear the create variable popup name input - When enter the create variable popup name "Kybl" - When enter the create variable popup Monaco Editor text: - """ - buckets() - |> filter(fn: (r) => r.name !~ /^_/) - |> rename(columns: {name: '_value'}) - |> keep(columns: ['_value']) - """ - When click the create variable popup create button - Then popup is not loaded - Then the success notification contains "Successfully created new variable: Kybl" - Then close all notifications - Then there is a variable card for "Kybl" - - Scenario: Filter Variables By Name - When enter the value "yb" into the variables filter - Then the variable cards "Kybl,Ryby" are visible - Then the variable cards "Arsenal,Bucket,Jehlicnany,Obdobi,Primaty,Reals,Slavia" are not present - Then the variable cards are sorted as "Kybl,Ryby" - When click the sort type dropdown - When click sort by item "Name Desc" - Then the variable cards are sorted as "Ryby,Kybl" - When click the sort type dropdown - When click sort by item "Name Asc" - #When click the variable sort by name button - When clear the variables filter - Then the variable cards "Arsenal,Bucket,Jehlicnany,Kybl,Obdobi,Primaty,Reals,Ryby,Slavia" are visible - - # Sort by type not working - TODO fix after Issue 15379 fixed - - Scenario: Sort Variables by name - Then the variable cards are sorted as "Arsenal,Bucket,Jehlicnany,Kybl,Obdobi,Primaty,Reals,Ryby,Slavia" - When click the sort type dropdown - When click sort by item "Name Desc" - #When click the variable sort by name button - # has third neutral state -- not any more - #When click the variable sort by name button - Then the variable cards are sorted as "Slavia,Ryby,Reals,Primaty,Obdobi,Kybl,Jehlicnany,Bucket,Arsenal" - When click the sort type dropdown - When click sort by item "Name Asc" - #When click the variable sort by name button - Then the variable cards are sorted as "Arsenal,Bucket,Jehlicnany,Kybl,Obdobi,Primaty,Reals,Ryby,Slavia" - - Scenario: Rename Variable - When hover over variable card named "Ryby" - When click the context menu of the variable "Ryby" - When click the context menu item "Rename" of the variable "Ryby" - Then the variable name warning popup is visible - Then dismiss the popup - Then popup is not loaded - When hover over variable card named "Ryby" - When click the context menu of the variable "Ryby" - When click the context menu item "Rename" of the variable "Ryby" - Then the variable name warning popup is visible - When click the rename variable warning popup understand button - When click popup cancel simple button - Then popup is not loaded - When hover over variable card named "Ryby" - When click the context menu of the variable "Ryby" - When click the context menu item "Rename" of the variable "Ryby" - When click the rename variable warning popup understand button - When clear the rename variable popup name input - Then the rename variable form warning states "Variable name cannot be empty" - Then the rename variable from warning icon is visible - Then the rename variable submit button is disabled - When enter the new variable name "Kocky" - When click rename variable popup submit button - Then the success notification contains "Successfully updated variable: Kocky." - Then close all notifications - Then there is a variable card for "Kocky" - - Scenario: Edit Map Variable to CSV - When click the variable card name "Kocky" - Then the edit variable popup is loaded - When click the edit variable popup type dropdown - When click the edit variable popup type dropdown item "constant" - Then the edit variable name input is disabled - When enter the edit variable popup values: - """ - Angora,Siamska,Barmska,Kartuzska,Ruska Modra - """ - When click the edit variable popup title - Then the create variable popup info line contains "5" items - Then the selected default variable dropdown item is "Angora" - When click the edit variable popup default dropdown - When click the edit variable popup default csv dropdown item "Kartuzska" - Then the selected default variable dropdown item is "Kartuzska" - When click the edit variable popup submit button - Then popup is not loaded - Then the success notification contains "Successfully updated variable: Kocky." - Then close all notifications - Then there is a variable card for "Kocky" - - - Scenario: Edit CSV Variable to Query - When click the variable card name "Slavia" - Then the edit variable popup is loaded - When click the edit variable popup type dropdown - When click the edit variable popup type dropdown item "query" - Then the edit variable name input is disabled - When enter the edit variable popup Query text: - """ - buckets() - |> filter(fn: (r) => r.name !~ /^_/) - |> rename(columns: {name: '_value'}) - |> keep(columns: ['_value']) - """ - When click the edit variable popup title - When click the edit variable popup submit button - Then popup is not loaded - Then the success notification contains "Successfully updated variable: Slavia." - Then close all notifications - Then there is a variable card for "Slavia" - - - Scenario: Edit Query Variable to Map - When click the variable card name "Kybl" - Then the edit variable popup is loaded - When click the edit variable popup type dropdown - When click the edit variable popup type dropdown item "map" - Then the edit variable name input is disabled - Then the edit variable popup textarea is cleared - When enter the edit variable popup values: - """ - kolac,tvarohovy - kobliha,jahodova - buchta,svestkova - babovka,vanilkova - loupak,cokoladovy - pernik,domaci - """ - When click the edit variable popup title - Then the create variable popup info line contains "6" items - Then the selected default variable dropdown item is "kolac" - When click the edit variable popup default dropdown - When click the edit variable popup default csv dropdown item "babovka" - Then the selected default variable dropdown item is "babovka" - When click the edit variable popup submit button - Then popup is not loaded - Then the success notification contains "Successfully updated variable: Kybl." - Then close all notifications - Then there is a variable card for "Kybl" - -@tested - Scenario Outline: Delete Variable - When hover over variable card named "<NAME>" - When click delete menu of variable card named "<NAME>" - When click delete confirm of variable card named "<NAME>" - Then the success notification contains "Successfully deleted the variable" - Then the variable card "<NAME>" is not present - - Examples: - |NAME| - |Kybl| - |Kocky | - |Jehlicnany| - |Slavia | - |Arsenal | - |Bucket | - |Obdobi | - |Primaty | - |Reals | diff --git a/e2e/features/signin/signin.feature b/e2e/features/signin/signin.feature deleted file mode 100644 index 63252f5b46..0000000000 --- a/e2e/features/signin/signin.feature +++ /dev/null @@ -1,36 +0,0 @@ -@feature-signin -@signin-signin -Feature: Signin - Use and abuse the signin page - - Scenario: Basic Signin - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When clear browser storage - #Then the heading contains "InfluxData" - Then the InfluxData heading is visible - Then the version shown contains "DEFAULT" - #Then the credits are valid - When enter the username "DEFAULT" - When enter the password "DEFAULT" - When click the signin button - Then the home page is loaded - -@tested - Scenario Outline: Signin Bad Credentials - Given I reset the environment - Given run setup over REST "DEFAULT" - When open the signin page - When enter the username "<USERNAME>" - When enter the password "<PASSWORD>" - When click the signin button - Then the error notification contains "<MESSAGE>" - - Examples: - | USERNAME | PASSWORD | MESSAGE | - | wumpus | DEFAULT | Could not sign in | - | DEFAULT | wuumpuus | Could not sign in | - - - # N.B. TODO - consider Security scenarios - Brute force password, injection attack diff --git a/e2e/hooks.js b/e2e/hooks.js deleted file mode 100644 index f82130a265..0000000000 --- a/e2e/hooks.js +++ /dev/null @@ -1,156 +0,0 @@ -const fs = require('fs') -var {Before, After, AfterAll, Status} = require('cucumber'); -var {logging} = require('selenium-webdriver'); -var perfUtils = require(__srcdir + '/utils/performanceUtils.js'); - -/* -Before(function (scenario, callback) { - callback(); -}); - -BeforeAll(async function (scenario, callback) { -// await __wdriver.get('chrome://settings/clearBrowserData').then(async () => { -// console.log("DEBUG clearing browser cache"); -// await __wdriver.sleep(3000); -// await __wdriver.switchTo().activeElement(); -//// await __wdriver.findElement(By.css("* /deep/ #clearBrowsingDataConfirm")).click(); -// await __wdriver.findElement(By.css("clearBrowsingDataConfirm")).click(); -// await __wdriver.sleep(3000); -// }).catch(async err => { -// console.log("DEBUG caught err " + err); -// throw err; -// }); - callback(); -})*/ - -async function writeScreenShot(filename) { - filename = filename.replace(/\s+/g, '_'); - return await __wdriver.takeScreenshot().then(async (image, err) => { - - await fs.writeFile(filename, image, 'base64', (err) => { - if (err) { - console.log(err) - } - }) - - return image - }) -} - -async function writeConsoleLog(filename){ - filename = filename.replace(/\s+/g, '_'); - await __wdriver.manage().logs().get(logging.Type.BROWSER).then(async logs => { - for(let log in logs){ - fs.appendFileSync(filename, `[${(new Date(parseInt(logs[log].timestamp))).toISOString()}]${logs[log].level}:${logs[log].message}\n`); - } - }) - -} - -async function writeDriverLog(filename){ - filename = filename.replace(/\s+/g, '_'); - await __wdriver.manage().logs().get(logging.Type.DRIVER).then(async logs => { - for(let log in logs){ - fs.appendFileSync(filename, `[${(new Date(parseInt(logs[log].timestamp))).toISOString()}]:${logs[log].message}\n`); - } - }) - -} - - - -let scenarioCt = 0; -let currentFeature = ''; - -Before(async function (scenario){ - - __currentFeature = scenario.sourceLocation.uri.substring(scenario.sourceLocation.uri.lastIndexOf("/") + 1).replace('.','-') - __currentScenario = scenario.pickle.name.trim(); - //safety kill any live data generator - if(!await scenarioContainsTag(scenario, '@use-live-data') && __liveDataGenRunning){ - console.log("killing live generator"); - __killLiveDataGen = true; - } -}); - -async function scenarioContainsTag(scenario, tag){ - let match = scenario.pickle.tags.find( elem => elem.name === tag) - //console.log("DEBUG match " + match); - return match !== undefined; -} - -After(async function (scenario /*, callback */) { - - //__wdriver.sleep(1500) //DEBUG - getting shots out of order -// Handled in cucumber.js - // if(!fs.existsSync(`./${__config.screenshot_dir}`)){ - // fs.mkdir(`./${__config.screenshot_dir}`, () => {}) - // } - - __reportedResetOnce = true; - - let uri = scenario.sourceLocation.uri - let feature = uri.substring(uri.lastIndexOf("/") + 1).replace('.','-') - let name = scenario.pickle.name.trim().replace(' ', '_'); - name = name.replace('/', '-'); - name = name.replace('\\', '-'); - - if(feature !== currentFeature){ - scenarioCt = 0; - } - - if(scenarioCt === 0){ - currentFeature = feature; - } - // let now = new Date() - // let nowStr = now.getFullYear().toString() + - // (now.getMonth() + 1).toString().padStart(2, '0') + - // now.getDate().toString().padStart(2, '0') + "-" + - // now.getHours().toString().padStart(2, '0') + - // now.getMinutes().toString().padStart(2, '0') + - // now.getSeconds().toString().padStart(2, '0') - //let filebase = __config.screenshot_dir + '/' + feature + "-" + nowStr + "-" + name - let filebase = __screenShotDir + "/" + feature + "-" + (scenarioCt++).toString().padStart(2, '0') + "-" + name; - let world = this; - - if(scenario.result.status === Status.FAILED){ - await writeScreenShot(filebase + "-ERR" + ".png").then(async img => { - await world.attach(img, 'image/png') - }); - await writeConsoleLog(filebase + '-ERR-console.log').catch(async e => { - throw('failed to write ' + filebase + '-ERR-console.log\n' + e); - }); - await writeDriverLog(filebase + '-ERR-driver.log').catch(async e => { - throw('failed to write ' + filebase + '-ERR-console.log\n' + e); - }) - - }else { - await writeScreenShot(filebase + "--OK" + ".png").then(async img => { - await world.attach(img, 'image/png') - }) - } - - //callback() - -}); - - - -AfterAll(async function ( ) { - - __reportedResetOnce = false; - - if(__liveDataGenRunning) { - console.log("killing live generator"); - __killLiveDataGen = true; - } - - if(perfUtils.performanceLog.length > 0){ - await perfUtils.writePerformanceLog(); - await perfUtils.writePerformanceReport(); - } -}); - - - - diff --git a/e2e/package.json b/e2e/package.json deleted file mode 100644 index c75b35b1c6..0000000000 --- a/e2e/package.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "name": "selenium-accept", - "version": "0.0.1", - "description": "selenium acceptance tests for influxdbv2 ui", - "main": "index.js", - "scripts": { - "clean": "rm -rdf screenshots/*; rm report/*", - "influx:setup": "cd scripts && ./influxdb2_community_test_env.sh setup-qa && cd -", - "influx:stop": "./scripts/influxdb2_community_test_env.sh stop", - "influx:clean": "./scripts/influxdb2_community_test_env.sh clean", - "test": "mkdirp report && cucumber-js", - "report:html": "chmod 775 src/utils/htmlReport.js; src/utils/htmlReport.js", - "report:junit": "chmod 775 src/utils/junitReport.js; src/utils/junitReport.js", - "kill:chrome": "killall chrome || true" - }, - "author": "", - "license": "ISC", - "devDependencies": { - "axios": "^0.19.0", - "babel-cli": "^6.26.0", - "babel-core": "^6.26.3", - "babel-preset-env": "^1.7.0", - "chai": "^4.2.0", - "chai-match": "^1.1.1", - "chromedriver": "^85.0.0", - "copy-paste": "^1.3.0", - "csv": "^5.3.1", - "cucumber": "^5.1.0", - "cucumber-html-reporter": "^5.0.0", - "cucumber-junit-convert": "^1.0.2", - "cucumber-pretty": "^1.5.2", - "eslint": "^7.1.0", - "geckodriver": "^1.16.2", - "mkdirp": "^0.5.1", - "selenium-webdriver": "^4.0.0-alpha.7" - }, - "dependencies": { - "@influxdata/influxdb-client": "^1.3.0", - "@influxdata/influxdb-client-apis": "^1.3.0", - "expect.js": "^0.3.1" - } -} diff --git a/e2e/scripts/Dockerfile b/e2e/scripts/Dockerfile deleted file mode 100644 index a1bd1ea1bc..0000000000 --- a/e2e/scripts/Dockerfile +++ /dev/null @@ -1,3 +0,0 @@ -FROM quay.io/influxdb/influx:nightly - -ENTRYPOINT ["/entrypoint.sh", "--e2e-testing=true"] diff --git a/e2e/scripts/Dockerfile.cloud b/e2e/scripts/Dockerfile.cloud deleted file mode 100644 index 76f9d16926..0000000000 --- a/e2e/scripts/Dockerfile.cloud +++ /dev/null @@ -1,15 +0,0 @@ -FROM node:12.16 - -USER root - -COPY package.json /home/e2e/package.json - -WORKDIR /home/e2e - -RUN npm install - -COPY . /home/e2e - -ENV PATH $PATH:./node_modules/.bin - -ENTRYPOINT scripts/cloud-test.sh diff --git a/e2e/scripts/Dockerfile.e2e b/e2e/scripts/Dockerfile.e2e deleted file mode 100644 index 5f89676a8c..0000000000 --- a/e2e/scripts/Dockerfile.e2e +++ /dev/null @@ -1,18 +0,0 @@ -FROM circleci/node:lts-stretch-browsers - -USER root - -COPY package.json /selenium-accept-infl2/package.json - -WORKDIR /selenium-accept-infl2 - -RUN npm install - -COPY . /selenium-accept-infl2 - -RUN \ - mkdir report - -ENV PATH $PATH:./node_modules/.bin - -CMD cucumber-js diff --git a/e2e/scripts/Dockerfile.tests b/e2e/scripts/Dockerfile.tests deleted file mode 100644 index 3d11a266d0..0000000000 --- a/e2e/scripts/Dockerfile.tests +++ /dev/null @@ -1,14 +0,0 @@ -FROM node:12.16 - -USER root - -COPY package.json /home/e2e/package.json - -WORKDIR /home/e2e - -RUN npm install - -COPY . /home/e2e - -ENV PATH $PATH:./node_modules/.bin - diff --git a/e2e/scripts/circleci-run.sh b/e2e/scripts/circleci-run.sh deleted file mode 100755 index 403996bcbd..0000000000 --- a/e2e/scripts/circleci-run.sh +++ /dev/null @@ -1,33 +0,0 @@ -!#/usr/bin/env bash - -sleep 30 - -sudo netstat -tlnp -curl -v --connect-timeout 60 --max-time 60 http://localhost:8086/debug/flush - -git clone https://github.com/influxdata/influxdb.git - -cd ~/project/influxdb/e2e/ - -npm install - -npm test -- features/loadData/telegrafs.feature - -TEST_RESULT=$? - -echo TEST_RESULT = $TEST_RESULT - -npm run report:junit -npm run report:html - -echo "Saving Test Results" - -mkdir -p ~/test-results/cucumber -mkdir -p ~/test-results/html -pwd -cp ~/project/influxdb/e2e/report/cucumber_junit.xml ~/test-results/cucumber/junit.xml -cp ~/project/influxdb/e2e/report/cucumber_report.html ~/test-results/html/cucumber_report.html -cp ~/project/influxdb/e2e/report/cucumber_report.json ~/test-results/cucumber/report.cucumber -cp -r ~/project/influxdb/e2e/screenshots ~/test-results - -exit $TEST_RESULT diff --git a/e2e/scripts/cloud-test.sh b/e2e/scripts/cloud-test.sh deleted file mode 100755 index 89f432e917..0000000000 --- a/e2e/scripts/cloud-test.sh +++ /dev/null @@ -1,6 +0,0 @@ -#!/usr/bin/env bash - -npm test -- activeConf=cloud cloud -sleep 15 -npm run report:html -npm run report:junit diff --git a/e2e/scripts/containerTests.sh b/e2e/scripts/containerTests.sh deleted file mode 100755 index bc8ff07cb7..0000000000 --- a/e2e/scripts/containerTests.sh +++ /dev/null @@ -1,140 +0,0 @@ -#!/usr/bin/env bash - -APP_ROOT="$(dirname "$(dirname "$(readlink -fm "$0")")")" -TEST_CONTAINER=bonitoo_e2e -INFLUX2_CONTAINER=influx2_solo -E2E_MAP_DIR=/tmp/e2e -INFLUX2_HOST=$(sudo docker inspect -f "{{ .NetworkSettings.IPAddress }}" ${INFLUX2_CONTAINER}) -INFLUX2_URL="http://${INFLUX2_HOST}:8086" -#TAGS="@influx-influx" -ACTIVE_CONF=development - -POSITIONAL=() -while [[ $# -gt 0 ]] -do -key="$1" - -case $key in - -t| --tags) - TAGS="$2" - shift; # past argument - shift; # past val - ;; - -c| --config) - ACTIVE_CONF="$2" - shift; - shift; - ;; - -b| --base) - BASE_DIR="$2" - shift; - shift; -esac -done - -echo E2E_CLOUD_DEFAULT_USER_USERNAME = ${E2E_CLOUD_DEFAULT_USER_USERNAME} - -echo Working from ${APP_ROOT} - -DOCKER_TEST_CMD="npm test -- activeConf=${ACTIVE_CONF}" - -if [[ -n "${TAGS}" ]]; then - DOCKER_TEST_CMD="${DOCKER_TEST_CMD} --tags ${TAGS}" -fi - -if [[ -n "${BASE_DIR+x}" ]]; then - DOCKER_TEST_CMD="${DOCKER_TEST_CMD} ${BASE_DIR}" -fi - -echo DOCKER_TEST_CMD = ${DOCKER_TEST_CMD} - -if [ ${ACTIVE_CONF} = 'cloud' ]; then - echo configuring for cloud - if [ -z ${E2E_CLOUD_INFLUX_URL+x} ]; then - echo - echo E2E_CLOUD_INFLUX_URL is unset - echo But cloud configuration chosen - echo - echo Please set E2E_CLOUD_INFLUX_URL to use cloud configuration - exit 1 - else - echo E2E_CLOUD_INFLUX_URL ${E2E_CLOUD_INFLUX_URL} - INFLUX2_URL=${E2E_CLOUD_INFLUX_URL} - fi - - if [ -z ${E2E_CLOUD_DEFAULT_USER_PASSWORD} ]; then - echo - echo E2E_CLOUD_DEFAULT_USER_PASSWORD is unset - echo But cloud configuration chosen - echo - echo Please set E2E_CLOUD_DEFAULT_USER_PASSWORD to use cloud configuration - exit 1 - fi -fi - -echo "------ Targeting influx at ${INFLUX2_URL} ------" - - -# Tear down running test container -echo "----- Tearing down test container ${TEST_CONTAINER} ------" - -if docker container inspect ${TEST_CONTAINER} > /dev/null 2>&1 -then - - if [ "$( docker container inspect -f '{{.State.Running}}' ${TEST_CONTAINER} )" == "true" ]; then - - echo stopping ${TEST_CONTAINER} - sudo docker stop ${TEST_CONTAINER} - - fi - - echo removing ${TEST_CONTAINER} - sudo docker rm ${TEST_CONTAINER} - -fi - -# Ensure mapped dirs are current -echo "----- Ensuring linked dir for volumes is current ------" -if [ -L ${E2E_MAP_DIR}/etc ]; then - echo ${E2E_MAP_DIR}/etc is linked - echo removing ${E2E_MAP_DIR} - sudo rm -r ${E2E_MAP_DIR} -fi -sudo mkdir -p ${E2E_MAP_DIR} -echo linking ${APP_ROOT}/etc -sudo ln -s ${APP_ROOT}/etc ${E2E_MAP_DIR}/etc - -echo "------ (Re)start Selenoid ------" -source ${APP_ROOT}/scripts/selenoid.sh -echo SELENOID_HOST is ${SELENOID_HOST} - -# Rebuild and start test container -echo "----- Rebuilding test container ${TEST_CONTAINER} ------" -if [[ -d "$APP_ROOT/report" ]]; then - echo cleaning "$APP_ROOT/report" - sudo npm run clean - rm -rdf report -fi - -DOCKER_ENVARS="-e SELENIUM_REMOTE_URL=http://${SELENOID_HOST}:4444/wd/hub -e E2E_${ACTIVE_CONF^^}_INFLUX_URL=${INFLUX2_URL}" - -if [ -n ${E2E_CLOUD_DEFAULT_USER_PASSWORD} ]; then - DOCKER_ENVARS="${DOCKER_ENVARS} -e E2E_CLOUD_DEFAULT_USER_PASSWORD=${E2E_CLOUD_DEFAULT_USER_PASSWORD}" -fi - -sudo docker build -t e2e-${TEST_CONTAINER} -f scripts/Dockerfile.tests . -sudo docker run -it -v `pwd`/report:/home/e2e/report -v `pwd`/screenshots:/home/e2e/screenshots \ - -v /tmp/e2e/etc:/home/e2e/etc -v /tmp/e2e/downloads:/home/e2e/downloads \ - ${DOCKER_ENVARS} --detach \ - --name ${TEST_CONTAINER} e2e-${TEST_CONTAINER}:latest - -echo ACTIVE_CONF ${ACTIVE_CONF} BASE_DIR ${BASE_DIR} TAGS ${TAGS} - -sudo docker exec ${TEST_CONTAINER} ${DOCKER_TEST_CMD} - -sudo docker exec ${TEST_CONTAINER} npm run report:html -sudo docker exec ${TEST_CONTAINER} npm run report:junit - -sudo docker stop ${TEST_CONTAINER} -sudo docker stop selenoid - diff --git a/e2e/scripts/influxdb2_community_test_env.sh b/e2e/scripts/influxdb2_community_test_env.sh deleted file mode 100755 index 1318df679e..0000000000 --- a/e2e/scripts/influxdb2_community_test_env.sh +++ /dev/null @@ -1,200 +0,0 @@ -#!/bin/sh - -USE_DOCKER=1 # Docker or tarball -USE_ALPHA=0 # alpha or nightly -DEBUG=0 -ACTION="setup" -TAR_DOWNLOAD="https://dl.influxdata.com/influxdb/releases/influxdb_2.0.0-alpha.1_linux_amd64.tar.gz" -DOCKER_IMAGE="quay.io/influxdb/influx:nightly" -INSTANCE_NAME="influx2_solo" -INFLUX2_HOME="${HOME}/.influxdbv2" -LOG_DIR=${PWD}/log -LOG_FILE=${LOG_DIR}/docker.log -TELEGRAF_DOWNLOAD="https://dl.influxdata.com/telegraf/releases/telegraf_1.8.2-1_amd64.deb" - - -download_telegraf(){ - echo "["$(date +"%d.%m.%Y %T")"] downloading telegraf.deb - if changed" -#curl -s -o telegraf.deb -z telegraf.deb https://dl.influxdata.com/telegraf/releases/telegraf_1.7.2-1_amd64.deb - curl -s -o telegraf.deb -z telegraf.deb https://dl.influxdata.com/telegraf/releases/telegraf_1.8.2-1_amd64.deb -} - -install_telegraf(){ - echo "["$(date +"%d.%m.%Y %T")"] installing telegraf.deb - if changed" - sudo dpkg -i telegraf.deb - echo "["$(date +"%d.%m.%Y %T")"] installed telegraf.deb - if changed" -} - - -stop_telegraf(){ - - echo "["$(date +"%d.%m.%Y %T")"] stoping telegraf.service - if changed" - sudo systemctl stop telegraf.service - echo "["$(date +"%d.%m.%Y %T")"] stoped telegraf.service - if changed" - -} - -pull_docker(){ - echo "["$(date +"%d.%m.%Y %T")"] pulling ${DOCKER_IMAGE}" - docker pull ${DOCKER_IMAGE} -} - -run_docker_influx(){ - mkdir -p ${LOG_DIR} - echo "["$(date +"%d.%m.%Y %T")"] starting docker instance ${INSTANCE_NAME}" - sudo docker run --name ${INSTANCE_NAME} --publish 8086:8086 ${DOCKER_IMAGE} > ${LOG_FILE} 2>&1 & - echo "["$(date +"%d.%m.%Y %T")"] started instance $INSTANCE_NAME listening at port 8086." - echo "logfile at $LOG_FILE" - sleep 3 - echo "\n$(tail -n32 $LOG_FILE)\n" -} - -run_docker_influx_test_env(){ - - mkdir -p ${LOG_DIR} - sudo docker stop $INSTANCE_NAME - sudo docker rm $INSTANCE_NAME - sudo docker pull quay.io/influxdb/influx:nightly - sudo docker build -t influxdb_test_image . - sudo docker run --name $INSTANCE_NAME --publish 8086:8086 influxdb_test_image > ${LOG_FILE} 2>&1 & - -} - -stop_docker_influx(){ - if [ "$(sudo docker ps -q -f name=$INSTANCE_NAME)" ] ; then - echo "["$(date +"%d.%m.%Y %T")"] stopping docker instance ${INSTANCE_NAME}" - sudo docker stop ${INSTANCE_NAME} - echo "["$(date +"%d.%m.%Y %T")"] stopped $INSTANCE_NAME" - fi -} - -remove_docker_influx(){ - if [ "$(sudo docker ps -a -q -f name=$INSTANCE_NAME)" ] ; then - echo "["$(date +"%d.%m.%Y %T")"] removing docker instance ${INSTANCE_NAME}" - sudo docker rm ${INSTANCE_NAME} - echo "["$(date +"%d.%m.%Y %T")"] removed $INSTANCE_NAME" - fi -} - -clean_influx_home(){ - echo "["$(date +"%d.%m.%Y %T")"] cleaning ${INFLUX2_HOME}" - sudo rm -rf ${INFLUX2_HOME} - echo "["$(date +"%d.%m.%Y %T")"] cleaned ${INFLUX2_HOME}" -} - -usage(){ - echo "usage $0" - echo " -a|--alpha use alpha release - otherwise nightly build is used" - echo " -t|--tarball use tarball build - otherwise docker is used" - echo " -n|--name set name of docker container - default $INSTANCE_NAME" - echo " setup|start start the service daemon - default action" - echo " shutdown|stop shutdown the service daemon" - echo " clean clean(remove) local directory ${INFLUX_HOME}" - echo " -h|--help print this message" -} - -# Will need to get the telegraf config on first creating org -# then restart telegraf... Will be part of test cases - -while [ "$1" != "" ]; do - case $1 in - -a | --alpha ) USE_ALPHA=1 - DOCKER_IMAGE="quay.io/influxdb/influxdb:2.0.0-alpha" - ;; - -t | --tarball ) USE_DOCKER=0 - ;; - -n | --name ) shift - INSTANCE_NAME=$1 - ;; - setup | start ) ACTION="setup" - ;; - setup-qa | start-qa ) ACTION="setup-qa" - ;; - stop | shutdown ) ACTION="stop" - ;; - clean ) ACTION="clean" - ;; - -h | --help ) usage - exit - ;; - -d | --debug ) DEBUG=1 - ;; - * ) usage - exit 1 - esac - shift -done - -if [ $DEBUG -gt 0 ] ; then - echo "USE_DOCKER $USE_DOCKER" - echo "USE_ALPHA $USE_ALPHA" - echo "ACTION $ACTION" - echo "TAR_DOWNLOAD $TAR_DOWNLOAD" - echo "DOCKER_IMAGE $DOCKER_IMAGE" - echo "INSTANCE_NAME $INSTANCE_NAME" - echo "INFLUX2_HOME $INFLUX2_HOME" - echo "LOG_FILE $LOG_FILE" - echo "TELEGRAF_DOWNLOAD $TELEGRAF_DOWNLOAD" -fi - -if [ $USE_ALPHA -ne 0 ] ; then - echo "USING ALPHA" -fi - -if [ $USE_ALPHA -eq 0 ] && [ $USE_DOCKER -eq 0 ] ; then - echo "Nightly builds with tar balls not supported at this time" - exit 1 -fi - -if [ $USE_DOCKER -eq 0 ] ; then - echo "tarball install - not yet supported" - exit -fi - -#if [ $USE_ALPHA -eq 0 ] && [ $USE_DOCKER -gt 0 ] ; then -case $ACTION in - setup ) stop_docker_influx - remove_docker_influx - download_telegraf - pull_docker - run_docker_influx - ;; - setup-qa) run_docker_influx_test_env - ;; - stop ) stop_docker_influx - ;; - clean ) clean_influx_home - ;; - * ) echo "Unhandled ACTION $ACTION" - exit 1 -esac - -#if [ "$ACTION" = "setup" ] ; then -# stop_docker_influx -# remove_docker_influx -# download_telegraf - # install_telegraf - # stop_telegraf -# pull_docker_nightly -# run_docker_influx -#elif [ "$ACTION" = "stop" ] ; then # stop docker nightly -# stop_docker_influx -# else -# echo "Unhandled ACTION $ACTION" -# exit 1 -#fi -#fi - -#if [ -z $1 ] ; then # check if first cmdline param is not set -# echo "["$(date +"%d.%m.%Y %T")"] USAGE: $0 [setup|start|stop]" -#elif [ "$1" = "setup" ] || [ "$1" = "start" ] ; then -# stop_docker_influx -# remove_docker_influx -# download_telegraf -## install_telegraf -## stop_telegraf -# pull_docker_nightly -# run_docker_influx -#elif [ "$1" = "stop" ] ; then -# stop_docker_influx -#fi diff --git a/e2e/scripts/selenoid.sh b/e2e/scripts/selenoid.sh deleted file mode 100755 index 69c685f71a..0000000000 --- a/e2e/scripts/selenoid.sh +++ /dev/null @@ -1,25 +0,0 @@ -#!/bin/bash - -APP_ROOT="$(dirname "$(dirname "$(readlink -fm "$0")")")" - -sudo docker stop selenoid -sudo docker rm selenoid - -sudo docker run -d --name selenoid -p 4444:4444 -v /var/run/docker.sock:/var/run/docker.sock \ - -v ${APP_ROOT}/etc/selenoid/config/:/etc/selenoid/:ro aerokube/selenoid:latest-release \ - -enable-file-upload -video-output-dir ${APP_ROOT}/etc/selenoid/video -timeout 5m0s - -sleep 10 - -export SELENOID_HOST=$(sudo docker inspect -f "{{ .NetworkSettings.IPAddress }}" selenoid) -echo SELENOID_HOST ${SELENOID_HOST} - -sudo docker pull selenoid/vnc:chrome_83.0 -#sudo docker pull selenoid/video-recorder:latest-release - -if [ "$1" = "-debug" ]; then - echo debugging - sudo docker stop selenoid-ui - sudo docker rm selenoid-ui - docker run -d --name selenoid-ui -p 8080:8080 aerokube/selenoid-ui --selenoid-uri http://${SELENOID_HOST}:4444 -fi diff --git a/e2e/src/pages/basePage.js b/e2e/src/pages/basePage.js deleted file mode 100644 index 9121e6ad2e..0000000000 --- a/e2e/src/pages/basePage.js +++ /dev/null @@ -1,394 +0,0 @@ -const { By, Condition, until, StaleElementReferenceError} = require('selenium-webdriver'); - -const notificationSuccessMsg = '[data-testid=notification-success] .notification--message'; -const notificationErrorMsg = '[data-testid=notification-error] .notification--message'; -const notificationPrimaryMsg = '[data-testid=notification-primary] .notification--message'; -const notificationCloseButton = '[data-testid^=notification-] button'; -const popupOverlayContainer = '[data-testid=overlay--container]'; -const popupFormElementError = '[data-testid=form--element-error]'; -const formInputError = '[data-testid=input-error]'; -const popupOverlay = '[data-testid=overlay]'; -const popupDismiss = '[data-testid=overlay--header] button[class*=dismiss]'; -const popupCancel = '[data-testid=overlay] button[data-testid=button--cancel]'; -const popupCancelSimple = '[data-testid=overlay--body] button[title=Cancel] '; -const popupWizardContinue = '[data-testid=overlay--body] [data-testid=next]'; -const popupSave = '[data-testid=overlay--container] button[data-testid=button--save] '; -const popupSaveSimple = '[data-testid=overlay--footer] button[title=\'Save\']'; -const popupCreate = '[data-testid=overlay--container] button[title=Create]'; -const popupSubmit = '[data-testid=button][type=submit]'; -const popupCopyToClipboard = '[data-testid=button-copy][title=\'Copy to Clipboard\']'; -const popupWizardBack = '[data-testid=overlay--body] [data-testid=back]'; -const popupWizardTitle = '[data-testid=overlay--body] .wizard-step--title'; -const popupWizardSubTitle = '[data-testid=overlay--body] .wizard-step--sub-title'; -const popupWizardDocsLink = '[data-testid=overlay--body] [data-testid=docs-link]'; -const popupWizardStepStateText = 'p.line-protocol--status:nth-of-type(1)'; -const popupTitle = '[data-testid=overlay--header] .cf-overlay--title'; -const codeMirror = 'div.CodeMirror'; -const monacoEditor = '.monaco-editor'; -const popupAlert = '[data-testid=alert]'; -const popupFileUpload = 'input[type=file]'; -const popupFileUploadHeader = '.drag-and-drop--header'; -const pageTitle = '[data-testid=page-title] '; -const popupBody = '[data-testid=overlay--body]'; -const popupGithubLink = '//a[contains(text(), \'GitHub Repository\')]'; -const popoverDialog = '[data-testid=popover--dialog]'; - -//generic controls -const sortTypeButton = '[data-testid=resource-sorter--button]'; -const sortTypeListItem = '[data-testid=\'resource-sorter--%ITEM%\']'; -const dropdownContents = '[data-testid=dropdown-menu--contents]'; -const dropdownItemByText = '//*[@data-testid=\'dropdown-item\'][./*[text()=\'%TEXT%\']]'; - -//common controls -const labelPopover = '[data-testid=\'inline-labels--popover--dialog\']'; -const labelListItem = '[data-testid=\'label-list--item %ITEM%\']'; -const labelPopoverFilterField = '[data-testid=\'inline-labels--popover-field\']'; -const labelPopoverCreateNewButton = '[data-testid=\'inline-labels--create-new\']'; - - -class basePage{ - - constructor(driver){ - this.driver = driver; - } - - delay(timeout){ - return new Promise((resolve) => { - setTimeout(resolve, timeout); - }); - } - - async waitUntilElementCss(selector){ - await this.driver.wait(until.elementLocated(By.css(selector))); - } - - async waitUntilElementVisibleCss(selector){ - await this.driver.wait(until.elementIsVisible(await this.driver.findElement(By.css(selector)))); - } - - - // selectors should be array of {type, selector} - async isLoaded(selectors, url = undefined){ - if(url){ - await this.driver.wait(until.urlContains(url), 5000); - } - - //selectors.forEach(async (selector) => { //N.B. for each seems to be swallowing thrown errors - for(let i = 0; i < selectors.length; i++) { - switch (selectors[i].type) { - case 'css': - await this.driver.wait(until.elementLocated(By.css(selectors[i].selector)), 5000); - break; - case 'xpath': - await this.driver.wait(until.elementLocated(By.xpath(selectors[i].selector)), 5000); - break; - default: - throw `Unknown selector type ${JSON.stringify(selectors[i])}`; - } - - // TODO - implement other selector types - } - //}); - } - - async getPopupOverlay(){ - return await this.driver.findElement(By.css(popupOverlay)); - } - - static getPopupOverlaySelector(){ - return { type: 'css', selector: popupOverlay}; - } - - async getNoficicationSuccessMsgs(){ - await this.waitUntilElementVisibleCss(notificationSuccessMsg); - return await this.driver.findElements(By.css(notificationSuccessMsg)); - } - - async getNotificationErrorMsgs(){ - await this.waitUntilElementVisibleCss(notificationErrorMsg); - return await this.driver.findElements(By.css(notificationErrorMsg)); - } - - async getNotificationPrimaryMsgs(){ - await this.waitUntilElementVisibleCss(notificationPrimaryMsg); - return await this.driver.findElements(By.css(notificationPrimaryMsg)); - - } - - async getNotificationCloseButtons(){ - return await this.driver.findElements(By.css(notificationCloseButton)); - } - - // selector shold be of {type, selector} - // helper to avoid stale element exceptions etc. - async smartGetElement(selector, timeout = this.driver.manage().getTimeouts().implicit) { - let resultElem; // check staleness with resultElem.enabled() or similar - for (let i = 0; i < 3; i++) { - try { - switch (selector.type) { - case 'css': - await this.driver.wait(until.elementLocated(By.css(selector.selector)), timeout); - resultElem = await this.driver.findElement(By.css(selector.selector)).catch(async err => { - console.log('DEBUG CAUGHT ERROR ' + JSON.stringify(err)); - console.log('AT ' + selector.selector); - throw err; - }); - break; - case 'xpath': - await this.driver.wait(until.elementLocated(By.xpath(selector.selector)), timeout); - resultElem = await this.driver.findElement(By.xpath(selector.selector)).catch(async err => { - console.log('DEBUG CAUGHT ERROR ' + JSON.stringify(err)); - console.log('AT ' + selector.selector); - throw err; - }); - break; - default: - throw `Unknown selector type ${JSON.stringify(selector)}`; - } - await resultElem.isEnabled(); - } catch (e) { - if (e instanceof StaleElementReferenceError && i !== 2) { - console.log('DEBUG caught ' + e); - //continue - try to get elem again - } else { - throw e; - } - } - } - return resultElem; - } - - // selector should be of {type, selector} - async getUntilElementNotPresent(selector){ - return new Condition('for no element to be located ' + selector, async () => { - switch(selector.type) { - case 'css': - return await this.driver.findElements(By.css(selector.selector)).then(function (elements) { - return elements.length === 0; - }); - case 'xpath:': - return await this.driver.findElements(selector).then(function (elements) { - return elements.length === 0; - }); - default: - throw `Unknown selector type ${JSON.stringify(selector)}`; - } - }); - } - - async getPopupOverlayContainer(){ - return await this.driver.findElement(By.css(popupOverlayContainer)); - } - - static getPopupOverlayContainerSelector(){ - return { type: 'css', selector: popupOverlayContainer}; - } - - async getPopupFormElementError(){ - return await this.driver.findElement(By.css(popupFormElementError)); - } - - static getPopupFormElementErrorSelector(){ - return { type: 'css', selector: popupFormElementError}; - } - - async getFormInputErrors(){ - return await this.driver.findElements(By.css(formInputError)); - } - - static getFormInputErrorSelector(){ - return { type: 'css', selector: formInputError}; - } - - async getPopupDismiss(){ - return await this.driver.findElement(By.css(popupDismiss)); - } - - async getPopupCancel(){ - return await this.driver.findElement(By.css(popupCancel)); - } - - async getPopupCancelSimple(){ - return await this.driver.findElement(By.css(popupCancelSimple)); - } - - async getPopupSave(){ - return await this.driver.findElement(By.css(popupSave)); - } - - async getPopupSaveSimple(){ - return await this.driver.findElement(By.css(popupSaveSimple)); - } - - async getPopupSubmit(){ - return await this.driver.findElement(By.css(popupSubmit)); - } - - async getPopupWizardContinue(){ - return await this.driver.findElement(By.css(popupWizardContinue)); - } - - static getPopupWizardContinueSelector(){ - return {type: 'css', selector: popupWizardContinue}; - } - - async getPopupWizardBack(){ - return await this.driver.findElement(By.css(popupWizardBack)); - } - - static getPopupWizardBackSelector(){ - return {type: 'css', selector: popupWizardBack}; - } - - async getPopupWizardTitle(){ - return await this.driver.findElement(By.css(popupWizardTitle)); - } - - static getPopupWizardTitleSelector(){ - return {type: 'css', selector: popupWizardTitle}; - } - - async getPopupWizardSubTitle(){ - return await this.driver.findElement(By.css(popupWizardSubTitle)); - } - - static getPopupWizardSubTitleSelector(){ - return {type: 'css', selector: popupWizardSubTitle}; - } - - async getPopupWizardDocsLink(){ - return await this.driver.findElement(By.css(popupWizardDocsLink)); - } - - async getPopupWizardStepStateText(){ - return await this.driver.findElement(By.css(popupWizardStepStateText)); - } - - async getPopupTitle(){ - return await this.driver.findElement(By.css(popupTitle)); - } - - async getCodeMirror(){ - return await this.driver.findElement(By.css(codeMirror)); - } - - async getMonacoEditor(){ - return await this.driver.findElement(By.css(monacoEditor)); - } - - async getPopupAlert(){ - return await this.driver.findElement(By.css(popupAlert)); - } - - async getPopupCopyToClipboard(){ - return await this.driver.findElement(By.css(popupCopyToClipboard)); - } - - async getPopupCreate(){ - return await this.driver.findElement(By.css(popupCreate)); - } - - - async getPopupFormElementMessage(){ - return await this.driver.findElement(By.css(popupFormElementError)); - } - - async getPopupFileUpload(){ - return await this.driver.findElement(By.css(popupFileUpload)); - } - - async getPopupFileUploadSelector(){ - return {type: 'css', selector: popupFileUpload}; - } - - async getPopupFileUploadHeader(){ - return await this.driver.findElement(By.css(popupFileUploadHeader)); - } - - async getPageTitle(){ - return await this.driver.findElement(By.css(pageTitle)); - } - - async getPopupBody(){ - return await this.driver.findElement(By.css(popupBody)); - } - - static getPopupBodySelector(){ - return { type: 'css', selector: popupBody }; - } - - async getPopupGithubLink(){ - return await this.driver.findElement(By.xpath(popupGithubLink)); - } - - async getSortTypeButton(){ - return await this.driver.findElement(By.css(sortTypeButton)); - } - - static getSortTypeButtonSelector(){ - return { type: 'css', selector: sortTypeButton } - } - - async getSortTypeListItem(item, normalize = true){ - if(normalize) { - return await this.driver.findElement(By.css(sortTypeListItem.replace('%ITEM%', item.toLowerCase() - .replace(" ", "-")))); - }else{ - return await this.driver.findElement(By.css(sortTypeListItem.replace('%ITEM%', item))); - } - } - - async getDropdownContents(){ - return await this.driver.findElement(By.css(dropdownContents)); - } - - static getDropdownContentsSelector(){ - return { type: 'css', selector: dropdownContents }; - } - - async getDropdownItemByText(text){ - return await this.driver.findElement(By.xpath(dropdownItemByText.replace('%TEXT%', text.trim()))); - } - - async getPopoverDialog(){ - return await this.driver.findElement(By.css(popoverDialog)); - } - - static getpopoverDialogSelector(){ - return { type: 'css', selector: popoverDialog }; - } - - async getLabelPopover(){ - return await this.driver.findElement(By.css(labelPopover)); - } - - static getLabelPopoverSelector(){ - return { type: 'css', selector: labelPopover }; - } - - async getLabelListItem(item){ - return await this.driver.findElement(By.css(labelListItem.replace('%ITEM%', item))); - } - - static getLabelListItemSelector(item){ - return { type: 'css', selector: labelListItem.replace('%ITEM%', item) }; - } - - async getLabelPopoverFilterField(){ - return await this.driver.findElement(By.css(labelPopoverFilterField)); - } - - async getLabelPopoverCreateNewButton(){ - return await this.driver.findElement(By.css(labelPopoverCreateNewButton)); - } - - static getLabelPopoverCreateNewButtonSelector(){ - return { type: 'css', selector: labelPopoverCreateNewButton }; - } - - - - -} - -module.exports = basePage; diff --git a/e2e/src/pages/cloud/cloudLoginPage.js b/e2e/src/pages/cloud/cloudLoginPage.js deleted file mode 100644 index f82c2892b0..0000000000 --- a/e2e/src/pages/cloud/cloudLoginPage.js +++ /dev/null @@ -1,55 +0,0 @@ -const { By, Condition, until, StaleElementReferenceError} = require('selenium-webdriver'); -const basePage = require(__srcdir + '/pages/basePage.js'); - -const emailInput = '[data-testid=\'input-field\']'; -const passwordInput = '[data-testid=\'visibility-input\']'; -const logInButton = '[data-testid=\'button\']'; -const logInPanel = '[data-testid=\'panel\']'; -const googleLoginButton = '[data-testid=button-base]'; -const signupLink = '//*[text()=\'Sign Up\']'; -const forgotPassLink = '//*[text()=\'Forgot Password\']'; - -const urlCtx = 'login'; - - -class cloudLoginPage extends basePage { - - constructor(driver) { - super(driver); - this.urlCtx = urlCtx; - this.driver = driver; - } - - async isLoaded(){ - await super.isLoaded([ - {type: 'css', selector: emailInput}, - {type: 'css', selector: passwordInput}, - {type: 'css', selector: logInButton}, - {type: 'css', selector: logInPanel}, - {type: 'css', selector: googleLoginButton}, - {type: 'xpath', selector: signupLink}, - {type: 'xpath', selector: forgotPassLink} - ], urlCtx); - } - - async waitToLoad(timeout = 10000){ - await this.driver.wait(until.elementLocated(By.css(logInPanel)), timeout, - `Login controls failed to load in ${timeout} milliseonds `); - } - - async getEmailInput(){ - return await this.driver.findElement(By.css(emailInput)); - } - - async getPasswordInput(){ - return await this.driver.findElement(By.css(passwordInput)); - } - - async getLogInButton(){ - return await this.driver.findElement(By.css(logInButton)); - } - -} - -module.exports = cloudLoginPage; - diff --git a/e2e/src/pages/createOrgPage.js b/e2e/src/pages/createOrgPage.js deleted file mode 100644 index 4271ea986e..0000000000 --- a/e2e/src/pages/createOrgPage.js +++ /dev/null @@ -1,51 +0,0 @@ -const basePage = require(__srcdir + '/pages/basePage.js'); -const { By } = require('selenium-webdriver'); - -const formOverlay = '[data-testid=overlay--children]'; -const formOverlayHeader = '[data-testid=overlay--header]'; -const formOverlayDismiss = '[data-testid=overlay--header] button.cf-overlay--dismiss'; -const inputOrgName = '[placeholder*=organization]'; -const inputBucketName = '[placeholder*=bucket]'; -const buttonCancel = 'button[title=Cancel]'; -const buttonCreate = 'button[title=Create]'; - -const urlCtx = 'orgs/new'; - -class createOrgPage extends basePage { - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: formOverlay}, - {type: 'css', selector: formOverlayHeader}, - {type: 'css', selector: formOverlayDismiss}, - {type: 'css', selector: inputOrgName}, - {type: 'css', selector: inputBucketName}, - {type: 'css', selector: buttonCancel}, - {type: 'css', selector: buttonCreate}, - ], urlCtx); - } - - async getInputOrgName(){ - return await this.driver.findElement(By.css(inputOrgName)); - } - - async getInputBucketName(){ - return await this.driver.findElement(By.css(inputBucketName)); - } - - async getbuttonCancel(){ - return await this.driver.findElement(By.css(buttonCancel)); - } - - async getbuttonCreate(){ - return await this.driver.findElement(By.css(buttonCreate)); - } - - - -} - -module.exports = createOrgPage; diff --git a/e2e/src/pages/dashboards/cellEditOverlay.js b/e2e/src/pages/dashboards/cellEditOverlay.js deleted file mode 100644 index d49ee497d7..0000000000 --- a/e2e/src/pages/dashboards/cellEditOverlay.js +++ /dev/null @@ -1,533 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const timeMachineOverlay = '[data-testid=overlay]'; -//const cellTitle = '[data-testid=overlay] [data-testid=page-header--left] [data-testid=page-title]'; -const cellTitle = '[data-testid=overlay] [data-testid=page-header] [data-testid=page-title]'; -const cellNameInput = ' [data-testid=renamable-page-title--input]'; -//const viewTypeDropdown = '[data-testid=overlay] [data-testid=page-header--right] [data-testid=\'view-type--dropdown\']'; -const viewTypeDropdown = '[data-testid=overlay] [data-testid=page-control-bar--left] [data-testid=\'view-type--dropdown\']'; -const viewTypeListContents = '[data-testid=\'view-type--dropdown\'] [data-testid=dropdown-menu--contents]'; -const viewTypeItem = '[data-testid=\'view-type--%ITEM%\']'; -//const customizeButton = '[data-testid=overlay] [data-testid=page-header--right] [data-testid=\'cog-cell--button\']'; -const customizeButton = '[data-testid=overlay] [data-testid=page-control-bar--left] [data-testid=\'cog-cell--button\']'; -//const editCancel = '[data-testid=overlay] [data-testid=page-header--right] [data-testid=\'cancel-cell-edit--button\']'; -const editCancel = '[data-testid=overlay] [data-testid=page-control-bar--right] [data-testid=\'cancel-cell-edit--button\']'; -//const saveCell = '[data-testid=overlay] [data-testid=page-header--right] [data-testid=\'save-cell--button\']'; -const saveCell = '[data-testid=overlay] [data-testid=page-control-bar--right] [data-testid=\'save-cell--button\']'; -const TMTop = '.time-machine--top'; -const TMBottom = '[data-testid=\'time-machine--bottom\']'; -const TMViewEmptyGraphQueries = '[data-testid=overlay] [data-testid=empty-graph--no-queries]'; -const TMViewNoResults = '[data-testid=overlay] [data-testid=empty-graph--no-results]'; -const TMResizerHandle = '[data-testid=overlay] [data-testid=draggable-resizer--handle]'; -const viewRawDataToggle = '[data-testid=overlay] .view-raw-data-toggle'; -const TMAutorefreshDropdown = '[data-testid=overlay] [data-testid=time-machine--bottom] .autorefresh-dropdown [data-testid=dropdown--button]'; -const TMAutorefreshDropdownPaused = '[data-testid=overlay] [data-testid=time-machine--bottom] .autorefresh-dropdown [data-testid=dropdown--button] [data-testid=\'icon\'].pause'; -const TMAutorefreshDropdownSelected = '[data-testid=overlay] [data-testid=time-machine--bottom] .autorefresh-dropdown [data-testid=dropdown--button] .cf-dropdown--selected'; -const TMAutorefreshItem = '//*[@data-testid=\'dropdown-item\'][./*[text()=\'%ITEM%\']]'; -const TMAutorefreshForceButton = '[class=time-machine] [class^=autorefresh-dropdown] [data-testid=square-button]'; -const TMTimeRangeDropdown = '[data-testid=overlay] [data-testid=time-machine--bottom] [data-testid=timerange-dropdown]'; -const TMTimeRangeDropdownItem = '[data-testid=dropdown-item-%ITEM%]'; -const TMTimeRangeDropdownContents = '[data-testid=dropdown-menu--contents]'; -const switchToScriptEditor = '[data-testid=overlay] [data-testid=time-machine--bottom] [data-testid=switch-to-script-editor] '; -const TMSwitchToQueryBuilder = '[data-testid=switch-query-builder-confirm--button]'; -const TMSwitchToQBuilderConfirm = '[data-testid=switch-query-builder-confirm--confirm-button]'; -const TMSwitchToQBuilderWarn = '[data-testid=switch-query-builder-confirm--popover--contents]'; -const timemachineSubmit = '[data-testid=time-machine-submit-button] '; -const TMQueryTabByName = '//*[contains(@class,\'query-tab \')][./*[@title=\'%NAME%\']]'; -const TMQueryBuilder = '[data-testid=query-builder]'; -//const functionSelect = '[data-testid=function-selector]'; -//const bucketSelect = '[data-testid=bucket-selector]'; -const TMBucketSelectorBucket = '[data-testid=bucket-selector] [data-testid=\'selector-list %NAME%\']'; -const TMBucketSelectorFilter = '[data-testid=bucket-selector] [data-testid=\'input-field\']'; -const TMBuilderCards = '[data-testid=builder-card]'; -const bucketSelectItem = '[data-testid=bucket-selector] [data-testid=\'selector-list %ITEM%\'] '; -const bucketSelectSearch = '[data-testid=bucket-selector] [data-testid=builder-card--menu] [class *= search]'; -const scriptEditorCodeMirror = '.CodeMirror'; -//const scriptMonacoEditor = '.monaco-editor'; -const scriptMonacoEditor = '.inputarea'; -const TMFluxEditor = '[data-testid=flux-editor]'; -const graphCanvas = '[data-testid=\'overlay\'] canvas[data-testid^=giraffe-layer]'; -const graphCanvasAxes = '[data-testid=\'overlay\'] canvas[data-testid=giraffe-axes]'; -const viewOptionsContainer = '.view-options'; -const TMEmptyGraphErrMessage = '.empty-graph-error pre'; -const TMDownloadCSV = '[data-testid=button][title*=\'CSV\']'; - -//Query builder -const TMQBSelectedBucket = '[data-testid=bucket-selector] [data-testid^=\'selector-list\'][class*=selected]'; -const TMQBSelectedTagOfCard = '//*[@data-testid=\'builder-card\'][.//*[@data-testid=\'tag-selector--container %INDEX%\']]//*[contains(@data-testid,\'selector-list\')][contains(@class,\'selected\')]'; -const TMBuilderCardMenuDurationInput = '[data-testid=\'duration-input\']'; -const TMBuilderCardMenuFunctionListItem = '[data-testid=\'selector-list %ITEM%\']'; -const TMBuilderCardMenuFunctionFilter = '[data-testid=\'input-field\'][placeholder*=\'functions\']'; -const TMBuilderCardMenuFunctionListItems = '[data-testid=function-selector] [data-testid^=\'selector-list\']'; -const TMQBSelectedFunctionsByName = '[data-testid=\'selector-list %NAME%\'].selected'; -const TMQBDurationSuggestions = '[data-testid=\'dropdown-menu--contents\'] [data-testid=\'dropdown-item\']'; -const TMQBDurationSuggestionByName = '//*[@data-testid=\'dropdown-menu--contents\']//*[@data-testid=\'dropdown-item\'][./*[text()=\'%NAME%\']]'; -const TMBuilderTabsAddQuery = '[data-testid=overlay] [class=time-machine-queries--tabs] [data-testid=square-button]'; -const TMQBActiveQueryTab = '.query-tab__active'; -const TMQBQueryTabByName = '//*[contains(@class,\'query-tab\')][./*[text()=\'%NAME%\']]'; -const TMQBRightClickItem = '[data-testid=\'right-click--%ITEM%-tab\']'; -const TMQBQueryTabNameInput = 'div.cf-input__focused input'; -const TMQBQueryTabs = '.time-machine-queries .query-tab'; -const TMQBCustomFunctionGroup = '[data-testid=custom-function]'; -const TMQBCustomWindowPeriod = '[data-testid=\'custom-window-period\']'; -const TMQBAutoWindowPeriod = '[data-testid=\'auto-window-period\']'; - -//Query Editor -const TMQEFunctionCategory = '//*[@class=\'flux-toolbar--heading\'][text()=\'%NAME%\']'; -const TMQEFunctionListItem = '[data-testid=\'flux--%NAME%\']'; -const TMQEFunctionListItemInjector = '[data-testid=\'flux--%NAME%--inject\']'; -const TMQEFunctionFilter = '.flux-toolbar--search [data-testid=\'input-field\']'; -const TMQEFunctionPopup = '[data-testid=\'toolbar-popover--contents\']'; -const TMQEFunctionPopupDescription = '[data-testid=\'toolbar-popover--contents\'] .flux-functions-toolbar--description span'; -const TMQEFunctionPopupSnippet = '//*[@data-testid=\'toolbar-popover--contents\']//*[@class=\'flux-function-docs--heading\'][text()=\'Example\']/../*[@class=\'flux-function-docs--snippet\']'; -const TMQEVariablesTab = '[data-testid=toolbar-tab][title=\'Variables\']'; -const TMQEVariablesLabel = '[data-testid=\'variable-name--%LABEL%\']'; -const TMQEVariablesInject = '[data-testid=\'variable--%VAR%--inject\']'; -const TMQEVariablesFilter = '[data-testid=input-field][placeholder^=\'Filter Variables\']'; -const TMQEVariablesPopover = '[data-testid=toolbar-popover--dialog]'; -const TMQEVariablesPopoverContents = '[data-testid=\'toolbar-popover--contents\']'; -const TMQEVariablePopoverDropdown = '[data-testid=\'variable--tooltip-dropdown\'] [data-testid=\'dropdown--button\'] .caret-down'; - -//RawData -const TMRawDataTable = '[data-testid=raw-data-table]'; -const TMRawDataToggle = '[data-testid=raw-data--toggle]'; -const TMRawDataReactGrid = '[data-testid=raw-data-table] [class=ReactVirtualized__Grid__innerScrollContainer]'; -const TMRawDataCells = '[class=\'raw-flux-data-table--cell\']'; -const TMRawDataCellByIndex = '[data-testid=raw-data-table] .raw-flux-data-table--cell:nth-of-type(%INDEX%)'; -const TMRawDataScrollTrackH = '[data-testid=raw-data-table] [class=fancy-scroll--track-h]'; -const TMRawDataScrollHThumb = '[data-testid=raw-data-table] [class=fancy-scroll--thumb-h]'; -const TMRawDataScrollTrackV = '[data-testid=raw-data-table] [class=fancy-scroll--track-v]'; -const TMRawDataScrollVThumb = '[data-testid=raw-data-table] [class^=fancy-scroll--thumb-v]'; - -const urlCtx = 'cells'; - -class cellEditOverlay extends influxPage { - - constructor(driver) { - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: cellTitle}, - {type: 'css', selector: viewTypeDropdown}, - {type: 'css', selector: customizeButton}, - {type: 'css', selector: editCancel}, - {type: 'css', selector: saveCell}, - {type: 'css', selector: TMResizerHandle}, - {type: 'css', selector: viewRawDataToggle}, - {type: 'css', selector: TMAutorefreshDropdown}, - {type: 'css', selector: TMTimeRangeDropdown}, - // {type: 'css', selector: switchToScriptEditor}, - {type: 'css', selector: timemachineSubmit}, - //{type: 'css', selector: queryBuilder}, - // {type: 'css', selector: functionSelect}, - //{type: 'css', selector: bucketSelect} - ], urlCtx); - } - - static getTimeMachineOverlay(){ - return {type: 'css', selector: timeMachineOverlay}; - } - - async getTMTop(){ - return await this.driver.findElement(By.css(TMTop)); - } - - async getTMBottom(){ - return await this.driver.findElement(By.css(TMBottom)); - } - - async getCellTitle(){ - return await this.driver.findElement(By.css(cellTitle)); - } - - async getCellNameInput(){ - return await this.driver.findElement(By.css(cellNameInput)); - } - - async getBucketSelectItem(item){ - return await this.driver.findElement(By.css(bucketSelectItem.replace('%ITEM%', item))); - } - - async getBucketSelectSearch(){ - return await this.driver.findElement(By.css(bucketSelectSearch)); - } - - static getBucketSelectSearchSelector(){ - return { type: 'css', selector: bucketSelectSearch }; - } - - async getEditCancel(){ - return await this.driver.findElement(By.css(editCancel)); - } - - async getSaveCell(){ - return await this.driver.findElement(By.css(saveCell)); - } - - async getTMTimeRangeDropdown(){ - return await this.driver.findElement(By.css(TMTimeRangeDropdown)); - } - - async getTMTimeRangeDropdownItem(item){ - //console.log("DEBUG selector " + TMTimeRangeDropdownItem.replace('%ITEM%', item)); - return await this.driver.findElement(By.css(TMTimeRangeDropdownItem.replace('%ITEM%', item))); - } - - async getTimemachineSubmit(){ - return await this.driver.findElement(By.css(timemachineSubmit)); - } - - async getSwitchToScriptEditor(){ - return await this.driver.findElement(By.css(switchToScriptEditor)); - } - - async getScriptEditorCodeMirror(){ - return await this.driver.findElement(By.css(scriptEditorCodeMirror)); - } - - async getScriptMonacoEditor(){ - return await this.driver.findElement(By.css(scriptMonacoEditor)); - } - - async getGraphCanvas(){ - return await this.driver.findElement(By.css(graphCanvas)); - } - - static getGraphCanvasSelector(){ - return { type: 'css', selector: graphCanvas }; - } - - async getGraphCanvasAxes(){ - return await this.driver.findElement(By.css(graphCanvasAxes)); - } - - static getGraphCanvasAxesSelector(){ - return { type: 'css', selector: graphCanvasAxes }; - } - - async getViewTypeDropdown(){ - return await this.driver.findElement(By.css(viewTypeDropdown)); - } - - async getViewTypeItem(item){ - return await this.driver.findElement(By.css(viewTypeItem.replace('%ITEM%', item))); - } - - async getViewTypeListContents(){ - return await this.driver.findElement(By.css(viewTypeListContents)); - } - - static getViewTypeListContentsSelector(){ - return { type: 'css', selector: viewTypeListContents }; - } - - async getCustomizeButton(){ - return await this.driver.findElement(By.css(customizeButton)); - } - - async getViewOptionsContainer(){ - return await this.driver.findElement(By.css(viewOptionsContainer)); - } - - static getViewOptionsContainerSelector(){ - return { type: 'css', selector: viewOptionsContainer }; - } - - async getTMViewEmptyGraphQueries(){ - return await this.driver.findElement(By.css(TMViewEmptyGraphQueries)); - } - - async getTMViewNoResults(){ - return await this.driver.findElement(By.css(TMViewNoResults)); - } - - async getTMAutorefreshDropdown(){ - return await this.driver.findElement(By.css(TMAutorefreshDropdown)); - } - - async getTMAutorefreshDropdownSelected(){ - return await this.driver.findElement(By.css(TMAutorefreshDropdownSelected)) - } - - async getTMAutorefreshDropdownPaused(){ - return await this.driver.findElement(By.css(TMAutorefreshDropdownPaused)); - } - - async getTMAutorefreshItem(item){ - return await this.driver.findElement(By.xpath(TMAutorefreshItem.replace('%ITEM%', item))); - } - - async getTMAutorefreshForceButton(){ - return await this.driver.findElement(By.css(TMAutorefreshForceButton)); - } - - static getTMAutorefreshForceButtonSelector(){ - return { type: 'css', selector: TMAutorefreshForceButton }; - } - - async getTMTimeRangeDropdownContents(){ - return await this.driver.findElement(By.css(TMTimeRangeDropdownContents)); - } - - static getTMTimeRangeDropdownContentsSelector(){ - return { type: 'css', selector: TMTimeRangeDropdownContents }; - } - - async getTMQueryTabByName(name){ - return await this.driver.findElement(By.xpath(TMQueryTabByName.replace('%NAME%',name))); - } - - async getTMQueryBuilder(){ - return await this.driver.findElement(By.css(TMQueryBuilder)); - } - - async getTMFluxEditor(){ - return await this.driver.findElement(By.css(TMFluxEditor)); - } - - async getTMDownloadCSV(){ - return await this.driver.findElement(By.css(TMDownloadCSV)); - } - - static getTMFluxEditorSelector(){ - return { type: 'css', selector: TMFluxEditor }; - } - - async getTMSwitchToQueryBuilder(){ - return await this.driver.findElement(By.css(TMSwitchToQueryBuilder)); - } - - async getTMSwitchToQBuilderConfirm(){ - return await this.driver.findElement(By.css(TMSwitchToQBuilderConfirm)); - } - - static getTMSwitchToQBuilderWarnSelector(){ - return { type: 'css', selector: TMSwitchToQBuilderWarn }; - } - - async getTMSwitchToQBuilderWarn(){ - return await this.driver.findElement(By.css(TMSwitchToQBuilderWarn)); - } - - async getTMBucketSelectorBucket(name){ - return await this.driver.findElement(By.css(TMBucketSelectorBucket.replace('%NAME%', name))); - } - - static getTMBucketSelectorBucketSelector(name){ - return { type: 'css', selector: TMBucketSelectorBucket.replace('%NAME%', name) }; - } - - async getTMBucketSelectorFilter(){ - return await this.driver.findElement(By.css(TMBucketSelectorFilter)); - } - - async getTMBuilderCards(){ - return await this.driver.findElements(By.css(TMBuilderCards)); - } - - async getTMBuilderCardByIndex(index){ - return (await this.driver.findElements(By.css(TMBuilderCards)))[index - 1]; - } - - async getTMBuilderCardMenuDurationInput(){ - return await this.driver.findElement(By.css(TMBuilderCardMenuDurationInput)); - } - - async getTMBuilderCardMenuFunctionListItem(item){ - return await this.driver.findElement(By.css(TMBuilderCardMenuFunctionListItem.replace('%ITEM%', item))); - } - - static getTMBuilderCardMenuFunctionListItemSelector(item){ - return { type: 'css', selector: TMBuilderCardMenuFunctionListItem.replace('%ITEM%', item) }; - } - - async getTMBuilderCardMenuFunctionFilter(){ - return await this.driver.findElement(By.css(TMBuilderCardMenuFunctionFilter)); - } - - async getTMBuilderCardMenuFunctionListItems(){ - return await this.driver.findElements(By.css(TMBuilderCardMenuFunctionListItems)); - } - - async getTMQBCustomFunctionGroup(){ - return await this.driver.findElement(By.css(TMQBCustomFunctionGroup)); - } - - async getTMQBCustomWindowPeriod(){ - return await this.driver.findElement(By.css(TMQBCustomWindowPeriod)); - } - - async getTMQBAutoWindowPeriod(){ - return await this.driver.findElement(By.css(TMQBAutoWindowPeriod)); - } - - async getTMQBDurationSuggestions(){ - return await this.driver.findElements(By.css(TMQBDurationSuggestions)); - } - - async getTMQBDurationSuggestionByName(name){ - return await this.driver.findElement(By.xpath(TMQBDurationSuggestionByName.replace('%NAME%', name))); - } - - async getTMResizerHandle(){ - return await this.driver.findElement(By.css(TMResizerHandle)); - } - - async getTMBuilderTabsAddQuery(){ - return await this.driver.findElement(By.css(TMBuilderTabsAddQuery)); - } - - async getTMQBSelectedBucket(){ - return await this.driver.findElement(By.css(TMQBSelectedBucket)); - } - - async getTMQBSelectedTagOfCard(index){ - return await this.driver.findElement(By.xpath(TMQBSelectedTagOfCard.replace('%INDEX%', index))); - } - - async getTMQBActiveQueryTab(){ - return await this.driver.findElement(By.css(TMQBActiveQueryTab)); - } - - async getTMQBQueryTabByName(name){ - return await this.driver.findElement(By.xpath(TMQBQueryTabByName.replace('%NAME%', name))); - } - - static getTMQBQueryTabSelectorByName(name){ - return { type: 'xpath', selector: TMQBQueryTabByName.replace('%NAME%', name)}; - } - - async getTMQBSelectedFunctionByName(name){ - return await this.driver.findElements(By.css(TMQBSelectedFunctionsByName.replace('%NAME%', name))); - } - - async getTMQBRightClickItem(item){ - return await this.driver.findElement(By.css(TMQBRightClickItem.replace('%ITEM%', item.toLowerCase().trim()))); - } - - async getTMQBQueryTabNameInput(){ - return await this.driver.findElement(By.css(TMQBQueryTabNameInput)); - } - - async getTMQBQueryTabs(){ - return await this.driver.findElements(By.css(TMQBQueryTabs)); - } - - async getTMEmptyGraphErrMessage(){ - return await this.driver.findElement(By.css(TMEmptyGraphErrMessage)); - } - - async getTMQEFunctionCategory(name){ - return await this.driver.findElement(By.xpath(TMQEFunctionCategory.replace('%NAME%', name))); - } - - async getTMQEFunctionListItem(name){ - return await this.driver.findElement(By.css(TMQEFunctionListItem.replace('%NAME%', name))); - } - - static getTMQEFunctionListItemSelector(name){ - return { type: 'css', selector: TMQEFunctionListItem.replace('%NAME%', name) }; - } - - async getTMQEFunctionListItemInjector(name){ - return await this.driver.findElement(By.css(TMQEFunctionListItemInjector.replace('%NAME%',name))); - } - - async getTMQEFunctionFilter(){ - return await this.driver.findElement(By.css(TMQEFunctionFilter)); - } - - async getTMQEFunctionPopupDescription(){ - return await this.driver.findElement(By.css(TMQEFunctionPopupDescription)); - } - - async getTMQEFunctionPopupSnippet(){ - return await this.driver.findElement(By.xpath(TMQEFunctionPopupSnippet)); - } - - static getTMQEFunctionPopupSelector(){ - return { type: 'css', selector: TMQEFunctionPopup }; - } - - async getTMRawDataTable(){ - return await this.driver.findElement(By.css(TMRawDataTable)); - } - - static getTMRawDataTableSelector(){ - return { type: 'css', selector: TMRawDataTable} - } - - async getTMRawDataToggle(){ - return await this.driver.findElement(By.css(TMRawDataToggle)); - } - - async getTMRawDataCells(){ - return await this.driver.findElements(By.css(TMRawDataCells)); - } - - async getTMRawDataReactGrid(){ - return await this.driver.findElement(By.css(TMRawDataReactGrid)); - } - - async getTMRawDataScrollTrackH(){ - return await this.driver.findElement(By.css(TMRawDataScrollTrackH)); - } - - async getTMRawDataScrollHThumb(){ - return await this.driver.findElement(By.css(TMRawDataScrollHThumb)); - } - - async getTMRawDataCellByIndex(index){ - return await this.driver.findElement(By.css(TMRawDataCellByIndex.replace('%INDEX%',index))); - } - - async getTMRawDataScrollTrackV(){ - return await this.driver.findElement(By.css(TMRawDataScrollTrackV)); - } - - async getTMRawDataScrollVThumb(){ - return await this.driver.findElement(By.css(TMRawDataScrollVThumb)); - } - - async getTMQEVariablesTab(){ - return await this.driver.findElement(By.css(TMQEVariablesTab)); - } - - async getTMQEVariablesLabel(label){ - return await this.driver.findElement(By.css(TMQEVariablesLabel.replace('%LABEL%', label))); - } - - static getTMQEVariablesLabelSelector(label){ - return { type: 'css', selector: TMQEVariablesLabel.replace('%LABEL%', label) } - } - - async getTMQEVariablesInject(variable){ - return await this.driver.findElement(By.css(TMQEVariablesInject.replace('%VAR%', variable))); - } - - async getTMQEVariablesFilter(){ - return await this.driver.findElement(By.css(TMQEVariablesFilter)); - } - - async getTMQEVariablesPopover(){ - return await this.driver.findElement(By.css(TMQEVariablesPopover)); - } - - static getTMQEVariablesPopoverSelector(){ - return { type: 'css', selector: TMQEVariablesPopover }; - } - - async getTMQEVariablePopoverDropdown(){ - return await this.driver.findElement(By.css(TMQEVariablePopoverDropdown)); - } - - async getTMQEVariablesPopoverContents(){ - return await this.driver.findElement(By.css(TMQEVariablesPopoverContents)); - } - - -} - -module.exports = cellEditOverlay; diff --git a/e2e/src/pages/dashboards/dashboardPage.js b/e2e/src/pages/dashboards/dashboardPage.js deleted file mode 100644 index 26a5229c31..0000000000 --- a/e2e/src/pages/dashboards/dashboardPage.js +++ /dev/null @@ -1,321 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const pageTitle = '[data-testid=page-title]'; -const nameInput = '[data-testid=renamable-page-title--input]'; -//const graphToolTips = '[data-testid=page-header--right] [data-testid=graphtips-question-mark]'; -const graphToolTips = '[data-testid=page-control-bar] [data-testid=graphtips-question-mark]'; -//const addCellButtonHeader = '//*[@data-testid=\'page-header--right\']//*[@data-testid=\'button\'][.//*[text()=\'Add Cell\']]'; -const addCellButtonHeader = '//*[@data-testid=\'page-control-bar--left\']//*[@data-testid=\'button\'][.//*[text()=\'Add Cell\']]'; -//const addNoteButton = '//*[@data-testid=\'page-header--right\']//*[@data-testid=\'button\'][.//*[text()=\'Add Note\']]'; -const addNoteButton = '[data-testid=add-note--button]'; -//const variablesButton = '//*[@data-testid=\'page-header--right\']//*[@data-testid=\'button\'][.//*[text()=\'Variables\']]'; -const variablesButton = '[data-testid=variables--button]'; -//const timeLocaleDropdown = '//*[@data-testid=\'page-header--right\']//*[@data-testid=\'dropdown--button\'][.//*[contains(@class,\'annotate\')]]'; -const timeLocaleDropdown = '//*[@data-testid=\'page-control-bar--right\']//*[@data-testid=\'dropdown--button\'][.//*[contains(@class,\'annotate\')]]'; -//const autorefresh = '//*[@data-testid=\'page-header--right\']/*[contains(@class,\'autorefresh-dropdown\')]'; -const autorefresh = '//*[@data-testid=\'page-control-bar--right\']/*[contains(@class,\'autorefresh-dropdown\')]'; -//const refreshRateDropdown = '//*[@data-testid=\'page-header--right\']//*[contains(@class,\'autorefresh\')]//*[@data-testid=\'dropdown--button\']'; -const refreshRateDropdown = '//*[@data-testid=\'page-control-bar--right\']//*[contains(@class,\'autorefresh\')]//*[@data-testid=\'dropdown--button\']'; -//const forceRefreshButton = '//*[@data-testid=\'page-header--right\']//*[contains(@class,\'autorefresh\')]//*[@data-testid=\'square-button\']'; -const forceRefreshButton = '//*[@data-testid=\'page-control-bar--right\']//*[contains(@class,\'autorefresh\')]//*[@data-testid=\'square-button\']'; -//const timeRangeDropdown = '//*[@data-testid=\'page-header--right\']//*[@data-testid=\'timerange-dropdown\']//*[@data-testid=\'dropdown--button\']'; -const timeRangeDropdown = '//*[@data-testid=\'page-control-bar--right\']//*[@data-testid=\'timerange-dropdown\']//*[@data-testid=\'dropdown--button\']'; -const timeRangeDropdownSelected = '[data-testid=\'timerange-dropdown\'] [class*=selected]'; -const timeRangeDropdownItem = '[data-testid=dropdown-item-past%ITEM%]'; -//const presentationModeButton = '//*[@data-testid=\'page-header--right\']//*[contains(@title,\'Presentation\')]'; -const presentationModeButton = '[data-testid=\'presentation-mode-toggle\']'; -const variableValueDropdownButtonForVar = '//*[@class=\'variable-dropdown\'][.//*[text()=\'%VARNAME%\']]//*[@data-testid=\'variable-dropdown--button\']'; -const variableValueDropdownItem = '//*[@class=\'variable-dropdown\'][.//*[text()=\'%VARNAME%\']]//*[@data-testid=\'variable-dropdown\']//*[@data-testid=\'variable-dropdown--item\'][.//*[text()=\'%ITEM%\']]' - -const dropdownMenuItem = '//*[@data-testid=\'dropdown-menu\']//*[contains(@data-testid,\'dropdown-item\')]/*[text()=\'%ITEM%\']'; -const dropdownMenuDivider = '//*[@data-testid=\'dropdown-menu\']//*[@data-testid=\'dropdown-divider\'][text()=\'%LABEL%\']'; - -const emptyStateTextLink = '[data-testid=\'empty-state--text\'] a'; -const emptyStateAddCellButton = '[data-testid=\'empty-state\'] [data-testid=\'add-cell--button\']'; - -const cellByName = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]'; -const cellEmptyGraphMessage = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'empty-graph--no-queries\']'; -const cellEmptyGraphNoResults = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'empty-graph--no-results\']'; -const cellEmptyGraphError = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'empty-graph--error\']'; -const cellEmptyGraphErrorIcon = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'empty-graph--error\']//*[contains(@class,\'empty-graph-error--icon\')]'; -const emptyGraphPopoverContents = '[data-testid^=emptygraph-popover--contents]'; -const cellTitle = '//*[@class=\'cell--header\'][./*[text()=\'%NAME%\']]'; -const cellHandleByName = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@class=\'cell--draggable\']'; -const cellResizerByName = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@class=\'react-resizable-handle\']'; -const cellContextToggleByName = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'cell-context--toggle\']'; -const cellNoteByName = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@class=\'cell--note-indicator\']'; -const cellPopoverContents = '[data-testid=popover--contents]'; -const cellPopoverContentsConfigure = '[data-testid=popover--contents] [data-testid=\'cell-context--configure\']'; -const cellPopoverContentsAddNote = '[data-testid=popover--contents] [data-testid=\'cell-context--note\']'; -const cellPopoverContentsClone = '[data-testid=popover--contents] [data-testid=\'cell-context--clone\']'; -const cellPopoverContentsDelete = '[data-testid=popover--contents] [data-testid=\'cell-context--delete\']'; -const cellPopoverContentsDeleteConfirm = '[data-testid=popover--contents] [data-testid=\'cell-context--delete-confirm\']'; -const cellPopoverContentsEditNote = '[data-testid=cell-context--note]'; -const cellCanvasLine = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'giraffe-layer-line\']'; -const cellCanvasAxes = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'giraffe-axes\']'; - -const cellHoverBox = '[data-testid=giraffe-layer-hover-line]'; - - -const notePopupCodeMirror = '[data-testid=overlay--body] .CodeMirror'; -const notePopupNoDataToggle = '[data-testid=overlay--body] [data-testid=slide-toggle]'; -const notePopupEditorPreview = '[data-testid=overlay--body] .note-editor--preview'; -const notePopupEditorPreviewTag = '[data-testid=overlay--body] .note-editor--preview %TAG%'; -const notePopupEditorPreviewText = '[data-testid=overlay--body] .note-editor--preview .markdown-format'; -const notePopupGuideLink = '[href*=\'markdownguide.org\']'; -const notePopupCancel = '[data-testid=overlay--footer] button[title=Cancel]'; -const notePopupSave = '[data-testid=overlay--footer] button[title=Save]'; - -const notePopover = '[data-testid=popover--dialog]'; -const notePopoverContents = '[data-testid=popover--dialog] .markdown-format'; - -const noteCellMarkdownTag = '[data-testid=\'cell--view-empty markdown\' ] .markdown-format %TAG%'; -const noteCellContextEdit = '[data-testid=cell-context--note]'; - -const urlCtx = 'dashboards'; - -class dashboardPage extends influxPage { - - constructor(driver) { - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: pageTitle}, - {type: 'css', selector: graphToolTips}, - {type: 'xpath', selector: addCellButtonHeader}, - {type: 'css', selector: addNoteButton}, - {type: 'css', selector: variablesButton}, - {type: 'xpath', selector: timeLocaleDropdown}, - {type: 'xpath', selector: autorefresh}, - {type: 'xpath', selector: timeRangeDropdown}, - {type: 'css', selector: presentationModeButton}], urlCtx); - } - - - async getPageTitle(){ - //return await this.driver.findElement(By.css(pageTitle)); - return await this.smartGetElement({type: 'css', selector: pageTitle}); - } - - async getNameInput(){ - return await this.driver.findElement(By.css(nameInput)); - } - - async getCellByName(name){ - return await this.driver.findElement(By.xpath(cellByName.replace('%NAME%', name))); - } - - static getCellSelectorByName(name){ - return {type: 'xpath', selector: cellByName.replace('%NAME%', name) }; - } - - async getCellsByName(name){ - return await this.driver.findElements(By.xpath(cellByName.replace('%NAME%', name))); - } - - async getGraphToolTips(){ - return await this.driver.findElement(By.css(graphToolTips)); - } - - async getAddCellButtonHeader(){ - return await this.driver.findElement(By.xpath(addCellButtonHeader)); - } - - async getAddNoteButton(){ - return await this.driver.findElement(By.css(addNoteButton)); - } - - async getVariablesButton(){ - return await this.driver.findElement(By.css(variablesButton)); - } - - async getTimeLocaleDropdown(){ - return await this.driver.findElement(By.xpath(timeLocaleDropdown)); - } - - async getRefreshRateDropdown(){ - return await this.driver.findElement(By.xpath(refreshRateDropdown)); - } - - async getForceRefreshButton(){ - return await this.driver.findElement(By.xpath(forceRefreshButton)); - } - - async getTimeRangeDropdown(){ - return await this.driver.findElement(By.xpath(timeRangeDropdown)); - } - - async getTimeRangeDropdownSelected(){ - return await this.driver.findElement(By.css(timeRangeDropdownSelected)); - } - - async getTimeRangeDropdownItem(item){ - return await this.driver.findElement(By.css(timeRangeDropdownItem.replace('%ITEM%', item))); - } - - async getPresentationModeButton(){ - return await this.driver.findElement(By.css(presentationModeButton)); - } - - async getEmptyStateTextLink(){ - return await this.driver.findElement(By.css(emptyStateTextLink)); - } - - async getEmptyStateAddCellButton(){ - return await this.driver.findElement(By.css(emptyStateAddCellButton)); - } - - async getDropdownMenuItem(item){ - return await this.driver.findElement(By.xpath(dropdownMenuItem.replace('%ITEM%', item))); - } - - async getdropdownMenuDivider(label){ - return await this.driver.findElement(By.xpath(dropdownMenuDivider.replace('%LABEL%', label))); - } - - async getCellEmptyGraphMessage(name){ - return await this.driver.findElement(By.xpath(cellEmptyGraphMessage.replace('%NAME%', name))); - } - - async getCellEmptyGraphNoResults(name){ - return await this.driver.findElement(By.xpath(cellEmptyGraphNoResults.replace('%NAME%', name))); - } - - async getCellEmptyGraphError(name){ - return await this.driver.findElement(By.xpath(cellEmptyGraphError.replace('%NAME%', name))); - } - - async getCellTitle(name){ - return await this.driver.findElement(By.xpath(cellTitle.replace('%NAME%', name))); - } - - async getCellHandleByName(name){ - return await this.driver.findElement(By.xpath(cellHandleByName.replace('%NAME%', name))); - } - - async getCellResizerByName(name){ - return await this.driver.findElement(By.xpath(cellResizerByName.replace('%NAME%', name))); - } - - static getCellPopoverContentsSelector(){ - return { type: 'css', selector: cellPopoverContents}; - } - - async getCellContextToggleByName(name){ - return await this.driver.findElement(By.xpath(cellContextToggleByName.replace('%NAME%', name))); - } - - async getCellPopoverContentsConfigure(){ - return await this.driver.findElement(By.css(cellPopoverContentsConfigure)); - } - - async getCellPopoverContentsAddNote(){ - return await this.driver.findElement(By.css(cellPopoverContentsAddNote)); - } - - async getCellPopoverContentsClone(){ - return await this.driver.findElement(By.css(cellPopoverContentsClone)); - } - - async getCellPopoverContentsDelete(){ - return await this.driver.findElement(By.css(cellPopoverContentsDelete)); - } - - async getCellPopoverContentsDeleteConfirm(){ - return await this.driver.findElement(By.css(cellPopoverContentsDeleteConfirm)); - } - - async getcellPopoverContentsEditNote(){ - return await this.driver.findElement(By.css(cellPopoverContentsEditNote)); - } - - async getNotePopupCodeMirror(){ - return await this.driver.findElement(By.css(notePopupCodeMirror)); - } - - async getNotePopupNoDataToggle(){ - return await this.driver.findElement(By.css(notePopupNoDataToggle)); - } - - async getNotePopupEditorPreview(){ - return await this.driver.findElement(By.css(notePopupEditorPreview)); - } - - async getNotePopupEditorPreviewText(){ - return await this.driver.findElement(By.css(notePopupEditorPreviewText)); - } - - async getNotePopupGuideLink(){ - return await this.driver.findElement(By.css(notePopupGuideLink)); - } - - async getNotePopupCancel(){ - return await this.driver.findElement(By.css(notePopupCancel)); - } - - async getNotePopupSave(){ - return await this.driver.findElement(By.css(notePopupSave)); - } - - async getCellNoteByName(name){ - return await this.driver.findElement(By.xpath(cellNoteByName.replace('%NAME%', name))); - } - - async getNotePopoverContents(){ - return await this.driver.findElement(By.css(notePopoverContents)); - } - - async getNotePopover(){ - return await this.driver.findElement(By.css(notePopover)); - } - - static getNotePopoverSelector(){ - return { type: 'css', selector: notePopover}; - } - - async getNotePopupEditorPreviewTag(tag){ - return await this.driver.findElement(By.css(notePopupEditorPreviewTag.replace('%TAG%', tag))); - } - - async getCellCanvasLine(name){ - return await this.driver.findElement(By.xpath(cellCanvasLine.replace('%NAME%', name))); - } - - async getCellCanvasAxes(name){ - return await this.driver.findElement(By.xpath(cellCanvasAxes.replace('%NAME%', name))); - } - - async getCellHoverBox(){ - return await this.driver.findElement(By.css(cellHoverBox)); - } - - async getEmptyGraphPopoverContents(){ - return await this.driver.findElement(By.css(emptyGraphPopoverContents)); - } - - async getCellEmptyGraphErrorIcon(name){ - return await this.driver.findElement(By.xpath(cellEmptyGraphErrorIcon.replace('%NAME%', name))); - } - - async getVariableValueDropdownButtonForVar(varname){ - return await this.driver.findElement(By.xpath(variableValueDropdownButtonForVar.replace('%VARNAME%', varname))); - } - - static getVariableValueDropdownButtonForVarSelector(varname){ - return {type: 'xpath', selector: variableValueDropdownButtonForVar.replace('%VARNAME%', varname)}; - } - - async getVariableValueDropdownItem(varname,item){ - return await this.driver.findElement(By.xpath(variableValueDropdownItem - .replace("%VARNAME%", varname) - .replace("%ITEM%", item))); - } - - async getNoteCellMarkdownTag(tag){ - return await this.driver.findElement(By.css(noteCellMarkdownTag.replace('%TAG%', tag))); - } -} - -module.exports = dashboardPage; diff --git a/e2e/src/pages/dashboards/dashboardsPage.js b/e2e/src/pages/dashboards/dashboardsPage.js deleted file mode 100644 index 1b9b9b5bc3..0000000000 --- a/e2e/src/pages/dashboards/dashboardsPage.js +++ /dev/null @@ -1,332 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const createDashboardDropdown = '[data-testid=add-resource-dropdown--button]'; -const filterDashboards = '[data-testid=search-widget]'; -const sortTypeButton = '[data-testid=resource-sorter--button]:nth-of-type(1)'; -const sortTypeItem = '[data-testid=\'resource-sorter--%ITEM%\']'; -const modifiedSortButton = '[data-testid=resource-list--sorter]:nth-of-type(2)'; -const createDashboardDropdownEmpty = '[data-testid=\'page-contents\'] [data-testid=\'add-resource-dropdown--button\']'; -const createDashboardItems = '[data-testid^=add-resource-dropdown--][id]'; -const dashboardCardByName = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]'; -const dashboardCardExportButton = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@class=\'context-menu--container\'][.//*[text() = \'Export\']]'; -const dashboardCardExportConfirm = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[text()=\'Export\']'; -const dashboardCardCloneButton = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@class=\'context-menu--container\'][.//*[text() = \'Clone\']]'; -const dashboardCardCloneConfirm = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@class=\'context-menu--container\']//*[text() = \'Clone\']'; -const dashboardCardDeleteButton = '//*[@data-testid=\'dashboard-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-delete-menu\']'; -const dashboardCardDeleteConfirm = '//*[@data-testid=\'dashboard-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-delete-dashboard\']'; -//const dashboardCardName = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'dashboard-card--name\']'; -const dashboardCardName = '//*[@data-testid=\'dashboard-card\']//span[text() = \'%NAME%\']'; -const dashboardCardNames = '[data-testid=\'dashboard-card--name\']'; -const dashboardCardNameButton = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'dashboard-card--name-button\']'; -const dashboardCardNameInput = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'dashboard-card--input\']'; -const dashboardCardDescription = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'resource-list--editable-description\']'; -const dashboardCardDescriptionEdit = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'resource-list--editable-description\']//*[@data-testid=\'icon\']'; -const dashboardCardDescriptionInput = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'resource-list--editable-description\']//*[@data-testid=\'input-field\']'; -const dashboardCardLabelsEmpty = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'inline-labels--empty\']'; -const dashboardCardAddLabels = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'inline-labels--add\']'; -const dashboardCardLabelPill = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'label--pill %LABEL%\']'; -const dashboardCardLabelPillDelete = '//*[@data-testid=\'dashboard-card\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'label--pill--delete %LABEL%\']'; -////*[@data-testid='dashboard-card'][.//*[text()='Test Dashboard']]//*[@data-testid='context-menu'] - -const addLabelsPopover = '[data-testid=\'inline-labels--popover\']'; -const addLabelsPopoverLabel = '//*[@data-testid=\'inline-labels--popover--contents\']//*[contains(@data-testid,\'label--pill\')][text()=\'%LABEL%\']'; -const addLabelsPopoverFilter = '[data-testid=\'inline-labels--popover-field\']'; -const addLabelsLabelPills = '[data-testid^=\'label--pill\']'; -const addLabelsPopoverListItem = '[data-testid^=\'label-list--item %ITEM%\']'; -const addLabelsPopoverNewItem = '[data-testid^=\'inline-labels--create-new\']'; - -const importPopupUploadFileRadio = '[data-testid=overlay--body] [data-testid=select-group--option][title=\'Upload\']'; -const importPopupPasteJSONRadio = '[data-testid=overlay--body] [data-testid=select-group--option][title=\'Paste\']'; -const importPopupImportJSONButton = '[data-testid=\'overlay--footer\'] [title^=\'Import JSON\']'; -const importPopupDismiss = '[data-testid=\'overlay--header\'] button'; -const importPopupFileInput = '[data-testid=\'overlay--body\'] [class*=\'drag-and-drop--form\'] '; -const importPopupFileInputHeader = '[data-testid=\'overlay--body\'] [class*=\'drag-and-drop--header\']'; -const importPopupDragNDropFile = 'input[type=file]'; //N.B. has display:none -const importPopupJSONTextarea = '[data-testid=\'overlay--body\'] [data-testid=\'import-overlay--textarea\']'; - -const fromTemplatePopupDismiss = '[data-testid=\'overlay--header\'] button'; -const fromTemplatePopupCancel = '[data-testid=\'overlay--footer\'] [data-testid=\'button\'][title=\'Cancel\']'; -const fromTemplatePopupCreateDBoard = '[data-testid=\'create-dashboard-button\']'; -const fromTemplatePopupTemplateList = '//*[@data-testid=\'dapper-scrollbars\'][.//*[contains(@data-testid, \'template--\')]]'; -const fromTemplatePopupTemplateItem = '[data-testid=\'template--%ITEM%\']'; -const fromTemplatePopupTemplatePanel = '[data-testid=\'template-panel\']'; -const fromTemplatePopupPreviewCell = '//*[@data-testid=\'template-panel\']//div[h5[text()=\'Cells\']]/p[text()=\'%NAME%\']'; - -const exportPopupDismiss = '[data-testid=\'overlay--header\'] [type=\'button\'][class*=dismiss]'; -const exportPopupCodeMirror = '.CodeMirror'; -const exportPopupDownloadJSON = '[data-testid=\'overlay--footer\'] [data-testid=\'button\'][title=\'Download JSON\']'; -const exportPopupSaveAsTemplate = '[data-testid=\'overlay--footer\'] [data-testid=\'button\'][title=\'Save as template\']'; -const exportPopupCopyToClipboard = '[data-testid=\'overlay--footer\'] [data-testid=\'button-copy\']'; - -const urlCtx = 'dashboards'; - -class dashboardsPage extends influxPage { - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: createDashboardDropdown}, - {type: 'css', selector: filterDashboards} , - {type: 'css', selector: sortTypeButton} - // {type: 'css', selector: modifiedSortButton} - ], urlCtx); - } - - async getCreateDashboardDropdown(){ - return await this.driver.findElement(By.css(createDashboardDropdown)); - } - - async getFilterDashboards(){ - return await this.driver.findElement(By.css(filterDashboards)); - } - - async getSortTypeButton(){ - return await this.driver.findElement(By.css(sortTypeButton)); - } - - async getSortTypeItem(item){ - return await this.driver.findElement(By.css(sortTypeItem.replace('%ITEM%', item))); - } - -// async getModifiedSortButton(){ -// return await this.driver.findElement(By.css(modifiedSortButton)); -// } - - async getCreateDashboardItem(item){ - return await this.driver.findElement(By.css(`[data-testid^=add-resource-dropdown--][id='${item}']`)); - } - - async getCreateDashboardDropdownEmpty(){ - return await this.driver.findElement(By.css(createDashboardDropdownEmpty)); - } - - static getCreateDashboardDropdownEmptySelector(){ - return { type: 'css', selector: createDashboardDropdownEmpty}; - } - - async getCreateDashboardItems(){ - return await this.driver.findElements(By.css(createDashboardItems)); - } - - async getDashboardCardByName(name){ - return await this.driver.findElement(By.xpath(dashboardCardByName.replace('%NAME%', name))); - } - - static getDashboardCardSelectorByName(name){ - return { type: 'xpath', selector: dashboardCardByName.replace('%NAME%', name) }; - } - - async getDashboardCardExportButton(name){ - return await this.driver.findElement(By.xpath(dashboardCardExportButton.replace('%NAME%', name))); - } - - static getDashboardCardExportButtonSelector(name){ - return { type: 'xpath', selector: dashboardCardExportButton.replace('%NAME%', name)}; - } - - async getDashboardCardExportConfirm(name){ - return await this.driver.findElement(By.xpath(dashboardCardExportConfirm.replace('%NAME%', name))); - } - - async getDashboardCardCloneButton(name){ - return await this.driver.findElement(By.xpath(dashboardCardCloneButton.replace('%NAME%', name))); - } - - static getDashboardCardCloneButtonSelector(name){ - return { type: 'xpath', selector: dashboardCardCloneButton.replace('%NAME%', name)}; - } - - - async getDashboardCardDeleteButton(name){ - return await this.driver.findElement(By.xpath(dashboardCardDeleteButton.replace('%NAME%', name))); - } - - static getDashboardCardDeleteButtonSelector(name){ - return { type: 'xpath', selector: dashboardCardDeleteButton.replace('%NAME%', name)}; - } - - async getDashboardCardName(name){ - return await this.driver.findElement(By.xpath(dashboardCardName.replace('%NAME%', name))); - } - - async getDashboardCardNameButton(name){ - return await this.driver.findElement(By.xpath(dashboardCardNameButton.replace('%NAME%', name))); - } - - async getDashboardCardNameInput(name){ - return await this.driver.findElement(By.xpath(dashboardCardNameInput.replace('%NAME%', name))); - } - - async getDashboardCardDescription(name){ - return await this.driver.findElement(By.xpath(dashboardCardDescription.replace('%NAME%', name))); - } - - async getDashboardCardDescriptionEdit(name){ - return await this.driver.findElement(By.xpath(dashboardCardDescriptionEdit.replace('%NAME%', name))); - } - - async getDashboardCardDescriptionInput(name){ - return await this.driver.findElement(By.xpath(dashboardCardDescriptionInput.replace('%NAME%', name))); - } - - async getDashboardCardLabelsEmpty(name){ - return await this.driver.findElement(By.xpath(dashboardCardLabelsEmpty.replace('%NAME%', name))); - } - - async getDashboardCardAddLabels(name){ - return await this.driver.findElement(By.xpath(dashboardCardAddLabels.replace('%NAME%', name))); - } - - async getAddLabelsPopoverLabel(label){ - return await this.driver.findElement(By.xpath(addLabelsPopoverLabel.replace('%LABEL%', label))); - } - - static getAddLabelsPopoverLabelSelector(label){ - return { type: 'xpath', selector: addLabelsPopoverLabel.replace('%LABEL%', label)}; - } - - async getAddLabelsPopoverFilter(){ - return await this.driver.findElement(By.css(addLabelsPopoverFilter)); - } - - async getAddLabelsLabelPills(){ - return await this.driver.findElements(By.css(addLabelsLabelPills)); - } - - async getAddLabelsPopoverListItem(item){ - return await this.driver.findElement(By.css(addLabelsPopoverListItem.replace('%ITEM%', item))); - } - - async getAddLabelsPopoverNewItem(){ - return await this.driver.findElement(By.css(addLabelsPopoverNewItem)); - } - - static getAddLabelsPopoverNewItemSelector(){ - return { type: 'css', selector: addLabelsPopoverNewItem }; - } - - async getDashboardCardLabelPill(name, label){ - return await this.driver.findElement(By.xpath(dashboardCardLabelPill - .replace('%NAME%', name).replace('%LABEL%', label))); - } - - static getDashboardCardLabelPillSelector(name, label){ - return { type: 'xpath', selector: dashboardCardLabelPill - .replace('%NAME%', name).replace('%LABEL%', label) }; - } - - async getAddLabelsPopover(){ - return await this.driver.findElement(By.css(addLabelsPopover)); - } - - static getAddLabelsPopoverSelector(){ - return { type: 'css', selector: addLabelsPopover}; - } - - async getDashboardCardLabelPillDelete(name, label){ - return await this.driver.findElement(By.xpath(dashboardCardLabelPillDelete - .replace('%NAME%', name).replace('%LABEL%', label))); - } - - async getImportPopupUploadFileRadio(){ - return await this.driver.findElement(By.css(importPopupUploadFileRadio)); - } - - async getImportPopupPasteJSONRadio(){ - return await this.driver.findElement(By.css(importPopupPasteJSONRadio)); - } - - async getImportPopupImportJSONButton(){ - return await this.driver.findElement(By.css(importPopupImportJSONButton)); - } - - async getImportPopupDismiss(){ - return await this.driver.findElement(By.css(importPopupDismiss)); - } - - async getImportPopupFileInput(){ - return await this.driver.findElement(By.css(importPopupFileInput)); - } - - static getImportPopupFileInputSelector(){ - return { type: 'css', selector: importPopupFileInput }; - } - - async getImportPopupFileInputHeader(){ - return await this.driver.findElement(By.css(importPopupFileInputHeader)); - } - - async getImportPopupDragNDropFile(){ - return await this.driver.findElement(By.css(importPopupDragNDropFile)); - } - - async getImportPopupJSONTextarea(){ - return await this.driver.findElement(By.css(importPopupJSONTextarea)); - } - - async getFromTemplatePopupDismiss(){ - return await this.driver.findElement(By.css(fromTemplatePopupDismiss)); - } - - async getFromTemplatePopupCancel(){ - return await this.driver.findElement(By.css(fromTemplatePopupCancel)); - } - - async getFromTemplatePopupCreateDBoard(){ - return await this.driver.findElement(By.css(fromTemplatePopupCreateDBoard)); - } - - async getFromTemplatePopupTemplateList(){ - return await this.driver.findElement(By.xpath(fromTemplatePopupTemplateList)); - } - - async getFromTemplatePopupTemplateItem(item){ - return await this.driver.findElement(By.css(fromTemplatePopupTemplateItem.replace('%ITEM%', item))); - } - - async getFromTemplatePopupTemplatePanel(){ - return await this.driver.findElement(By.css(fromTemplatePopupTemplatePanel)); - } - - async getfromTemplatePopupPreviewCell(name){ - return await this.driver.findElement(By.xpath(fromTemplatePopupPreviewCell.replace('%NAME%', name))); - } - - async getDashboardCardNames(){ - return await this.driver.findElements(By.css(dashboardCardNames)); - } - - async getDashboardCardDeleteConfirm(name){ - return await this.driver.findElement(By.xpath(dashboardCardDeleteConfirm.replace('%NAME%', name))); - } - - async getDashboardCardCloneConfirm(name){ - return await this.driver.findElement(By.xpath(dashboardCardCloneConfirm.replace('%NAME%', name))); - } - - async getExportPopupDismiss(){ - return await this.driver.findElement(By.css(exportPopupDismiss)); - } - - async getExportPopupCodeMirror(){ - return await this.driver.findElement(By.css(exportPopupCodeMirror)); - } - - async getExportPopupDownloadJSON(){ - return await this.driver.findElement(By.css(exportPopupDownloadJSON)); - } - - async getExportPopupSaveAsTemplate(){ - return await this.driver.findElement(By.css(exportPopupSaveAsTemplate)); - } - - async getexportPopupCopyToClipboard(){ - return await this.driver.findElement(By.css(exportPopupCopyToClipboard)); - } - -} - -module.exports = dashboardsPage; diff --git a/e2e/src/pages/dataExplorer/dataExplorerPage.js b/e2e/src/pages/dataExplorer/dataExplorerPage.js deleted file mode 100644 index a04b97ccfc..0000000000 --- a/e2e/src/pages/dataExplorer/dataExplorerPage.js +++ /dev/null @@ -1,301 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const timeLocaleDropdown = '[data-testid=select-dropdown]'; -const graphTypeDropdodwn = '[data-testid=page-control-bar--left] [data-testid=view-type--dropdown]'; -const customizeGraphButton = '[data-testid=page-control-bar--left] [data-testid=cog-cell--button]'; -const saveAsButton = '//button[./span[text() = \'Save As\']]'; -const viewArea = '.time-machine--view'; -const viewRawToggle = '[data-testid=raw-data--toggle]'; -const autorefreshDropdown = 'div.autorefresh-dropdown'; -//const pausedAutorefreshButton = 'button.autorefresh-dropdown--pause'; //Present only when autorefresh is paused - not good candidate for page loade check -const timeRangeDropdown = '//*[@data-testid=\'flex-box\']/div[3]'; -//const scriptEditToggle = '[data-testid=switch-to-script-editor] '; //N.B. disappears when in Script edit mode - not good candidate for page load check -//const queryBuildToggle = '[data-testid=switch-to-query-builder]'; //N.B. not present when in Query builder mode - not good candidate for page load check -const submitQueryButton = '[data-testid=time-machine-submit-button]'; -const bucketSelector = '[data-testid=bucket-selector]'; -const builderCard = '[data-testid=builder-card]'; -const graphCanvas = '[data-testid^=giraffe-layer]'; - -const cellCanvasLine = '//*[contains(@class, \' cell \')][.//*[text()=\'%NAME%\']]//*[@data-testid=\'giraffe-layer-line\']'; -const graphHoverLine = '[data-testid=giraffe-layer-hover-line]'; -const canvasAxes = '//*[@data-testid=\'giraffe-axes\']'; //'[@data-testid=\'giraffe-axes\']'; - -const refreshGraphButton = '//*[@class=\'autorefresh-dropdown--pause\'][@data-testid=\'square-button\']'; '//*[@class=\'cell--header\'][./*[text()=\'%NAME%\']]'; -const refreshDropdownPaused = '//*[@class=\'autorefresh-dropdown paused\'][.//*[@data-testid=\'dropdown\']]'; -const refreshDropdownActive = '//*[@class=\'autorefresh-dropdown\'][.//*[@data-testid=\'dropdown\']]'; -const refreshDropdownItem = '[id=\'auto-refresh-%ITEM%\']'; //'//*[@data-testid=\'dropdown-menu--contents\'][.//*[text()=\'%ITEM%\']]'; //*[contains(@class, ' cell ')][. '//*[id=\'auto-refresh-%ITEM%\'][@data-testid=\'dropdown-item\']'; - -const addQueryButton = '[class=time-machine-queries--tabs] [data-testid=square-button]'; -const queryTabByName = '//*[contains(@class,\'query-tab\')][./*[text()=\'%NAME%\']]'; -const queryTabMenuItem = '//*[@data-testid=\'right-click--%ITEM%-tab\']'; -const queryTabNameInput = '//*[contains(@class,\'query-tab__active\')][.//*[contains(@class,\'cf-input-xs\')]]'; - -const scriptEditorButton = '[data-testid=switch-to-script-editor]'; - -const scriptMonacoEditor = '.inputarea'; - -const viewTypeDropdown = '[data-testid=page-control-bar--left] [data-testid=\'view-type--dropdown\']'; -const viewType = '//*[@class=\'cf-dropdown-item--children\'][.//*[text()=\'%TYPE%\']]'; - -const singleStatText = '[data-testid=single-stat--text]'; -const rawDataToggle = '[data-testid=raw-data--toggle]'; -const rawDataTable = '[data-testid=raw-data-table]'; - -const functionSearchInput = '//*[@data-testid=\'function-selector\'][.//*[contains(@class,\'tag-selector--search\')]]'; - -const saveAsOverlayHeader = '[data-testid=save-as-overlay--header]'; -const targetDashboardDropdown = '[data-testid=save-as-dashboard-cell--dropdown]'; -const targetDashboardDropdownItem = '[data-testid=save-as-dashboard-cell--create-new-dash]'; -const newDashboardNameInput = '[data-testid=save-as-dashboard-cell--dashboard-name]'; -const cellNameInput = '[data-testid=save-as-dashboard-cell--cell-name]'; -const saveAsDashboardCellButton = '[data-testid=save-as-dashboard-cell--submit]'; -const saveAsPopupTabCell = '[data-testid=\'cell-radio-button\']'; -const saveAsPopupTabTask = '[data-testid=\'task--radio-button\']'; -const saveAsPopupTabVar = '[data-testid=\'variable-radio-button\']'; - -const taskNameInput = '[data-testid=\'task-form-name\']'; -const taskIntervalInput = '[data-testid=\'task-form-schedule-input\']'; -const taskOffsetInput = '[data-testid=\'task-form-offset-input\']'; -const saveAsTaskButton = '[data-testid=task-form-save]'; - -const variableNameInput = '[data-testid=\'input-field\'][placeholder=\'Give your variable a name\']'; -const saveAsVariableButton = '//*[@data-testid=\'button\'][.//*[text()=\'Save as Variable\']]'; - - - -//TODO - more controls - -const urlCtx = 'data-explorer'; - -class dataExplorerPage extends influxPage { - - constructor(driver){ - super(driver); - } - - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: timeLocaleDropdown}, - {type: 'css', selector: graphTypeDropdodwn}, - {type: 'css', selector: customizeGraphButton}, - {type: 'xpath', selector: saveAsButton}, - {type: 'css', selector: viewArea}, - {type: 'css', selector: viewRawToggle}, - {type: 'css', selector: autorefreshDropdown}, - {type: 'xpath', selector: timeRangeDropdown}, - {type: 'css', selector: submitQueryButton} - ], urlCtx); - } - - async getTimeLocaleDropdown(){ - return await this.driver.findElement(By.css(timeLocaleDropdown)); - } - - async getGraphTypeDropdown(){ - return await this.driver.findElement(By.css(graphTypeDropdodwn)); - } - - async getCustomizeGraphButton(){ - return await this.driver.findElement(By.css(customizeGraphButton)); - } - - async getSaveAsButton(){ - return await this.driver.findElement(By.xpath(saveAsButton)); - } - - async getViewArea(){ - return await this.driver.findElement(By.css(viewArea)); - } - - async getViewRawToggle(){ - return await this.driver.findElement(By.css(viewRawToggle)); - } - - async getAutoRefreshDropdown(){ - return await this.driver.findElement(By.css(autorefreshDropdown)); - } - - async getTimeRangeDropdown(){ - return await this.driver.findElement(By.xpath(timeRangeDropdown)); - } - - async getSubmitQueryButton(){ - return await this.driver.findElement(By.css(submitQueryButton)); - } - - async getBucketSelector(){ - return await this.driver.findElement(By.css(bucketSelector)); - } - - async getItemFromSelectorList(bucket){ - return await this.driver.findElement(By.css(`[data-testid='selector-list ${bucket}']`)); - } - - async getBuilderCard(){ - return await this.driver.findElements(By.css(builderCard)); - } - - async getBuilderCardByIndex(index){ - return (await this.driver.findElements(By.css(builderCard)))[index - 1]; - } - - async getGraphCanvas(){ - return await this.driver.findElement(By.css(graphCanvas)); - } - - async getCanvasLine(){ - return await this.driver.findElement(By.css(graphCanvas)); - } - - async getGraphHoverLine(){ - return await this.driver.findElement(By.css(graphHoverLine)); - } - - async getCanvasAxes(){ - return await this.driver.findElement(By.xpath(canvasAxes)); - } - - async getRefreshGraphButton(){ - return await this.driver.findElement(By.xpath(refreshGraphButton)); - } - - async getRefreshDropdownPaused(){ - return await this.driver.findElement(By.xpath(refreshDropdownPaused)); - } - - async getRefreshDropdownActive(){ - return await this.driver.findElement(By.xpath(refreshDropdownActive)); - } - - //async getRefreshDropdownItem(item){ - // return await this.driver.findElement(By.css(`[data-testid='dropdown-item'][id='auto-refresh-${item}']`)); - //} - - async getRefreshDropdownItem(item){ - return await this.driver.findElement(By.css(refreshDropdownItem.replace('%ITEM%', item))); - } - - async getAddQueryButton(){ - return await this.driver.findElement(By.css(addQueryButton)); - } - - async getQueryTabByName(name){ - return await this.driver.findElement(By.xpath(queryTabByName.replace('%NAME%', name))); - } - - async getQueryTabMenuItem(item){ - return await this.driver.findElement(By.xpath(queryTabMenuItem.replace('%ITEM%', item))); - } - - async getQueryTabNameInput(){ - return await this.driver.findElement(By.xpath(queryTabNameInput)); - } - - async getScriptEditorButton(){ - return await this.driver.findElement(By.css(scriptEditorButton)); - } - - async getScriptMonacoEditor(){ - return await this.driver.findElement(By.css(scriptMonacoEditor)); - } - - async getViewTypeDropdown(){ - return await this.driver.findElement(By.css(viewTypeDropdown)); - } - - async getViewType(type){ - return await this.driver.findElement(By.xpath(viewType.replace('%TYPE%', type))); - } - - async getSingleStatText(){ - return await this.driver.findElement(By.css(singleStatText)); - } - - async getRawDataToggle(){ - return await this.driver.findElement(By.css(rawDataToggle)); - } - - async getRawDataTable(){ - return await this.driver.findElement(By.css(rawDataTable)); - } - - async getTimeRangeDropdownItem(item){ - return await this.driver.findElement(By.css(`[data-testid='dropdown-item-past${item}']`)); - } - - async getFunctionSearchInput(){ - return await this.driver.findElement(By.xpath(functionSearchInput)); - } - - async getSelectorListFunction(funct){ - return await this.driver.findElement(By.css(`[data-testid='selector-list ${funct}']`)); - } - - async getSaveAsOverlayHeader(){ - return await this.driver.findElement(By.css(saveAsOverlayHeader)); - } - - async getTargetDashboardDropdown(){ - return await this.driver.findElement(By.css(targetDashboardDropdown)); - } - - async getTargetDashboardDropdownItem(){ - return await this.driver.findElement(By.css(targetDashboardDropdownItem)); - } - - async getNewDashboardNameInput(){ - return await this.driver.findElement(By.css(newDashboardNameInput)); - } - - async getCellNameInput(){ - return await this.driver.findElement(By.css(cellNameInput)); - } - - async getSaveAsDashboardCellButton(){ - return await this.driver.findElement(By.css(saveAsDashboardCellButton)); - } - - async getSaveAsPopupTabCell(){ - return await this.driver.findElement(By.css(saveAsPopupTabCell)); - } - - async getSaveAsPopupTabTask(){ - return await this.driver.findElement(By.css(saveAsPopupTabTask)); - } - - async getSaveAsPopupTabVar(){ - return await this.driver.findElement(By.css(saveAsPopupTabVar)); - } - - async getTaskNameInput(){ - return await this.driver.findElement(By.css(taskNameInput)); - } - - async getTaskIntervalInput(){ - return await this.driver.findElement(By.css(taskIntervalInput)); - } - - async getTaskOffsetInput(){ - return await this.driver.findElement(By.css(taskOffsetInput)); - } - - async getSaveAsTaskButton(){ - return await this.driver.findElement(By.css(saveAsTaskButton)); - } - - async getVariableNameInput(){ - return await this.driver.findElement(By.css(variableNameInput)); - } - - async getSaveAsVariableButton(){ - return await this.driver.findElement(By.xpath(saveAsVariableButton)); - } - - - - //TODO - more element getters - -} - -module.exports = dataExplorerPage; diff --git a/e2e/src/pages/home/homePage.js b/e2e/src/pages/home/homePage.js deleted file mode 100644 index 2e84a72d50..0000000000 --- a/e2e/src/pages/home/homePage.js +++ /dev/null @@ -1,88 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const logoutButton = '[title=Logout]'; -const getStartedDataCollect = '//*[@data-testid=\'panel\'][./div[contains(@class, \'getting-started\')]][.//span[text()=\'Load your data\']]'; -const getStartedDashboard = '//*[@data-testid=\'panel\'][./div[contains(@class, \'getting-started\')]][.//span[text()=\'Build a dashboard\']]'; -const getStartedAlerting = '//*[@data-testid=\'panel\'][./div[contains(@class, \'getting-started\')]][.//span[text()=\'Set up alerting\']]'; -const dataCollectButton = '[data-testid=button][title=\'Load your data\']'; -const dashboardButton = '[data-testid=button][title=\'Build a dashboard\']'; -const alertingButton = '[data-testid=button][title=\'Set up alerting\']'; -const tutorialsList = '//ul[contains(@class, \'tutorials\')]'; -const dashboardsList = '//*[./div/*[text()=\'Recent Dashboards\']]'; -const usefulLinkList = '//div[contains(@class,\'cf-col-sm-4 cf-col-md-3\')]//div[@data-testid=\'panel\'][3]//ul'; -//const dashboardLink = '//*[@data-testid=\'panel\'][.//*[text()=\'Dashboards\']]//ul/li/a[text()=\'%TEXT%\']'; -const dashboardLink = '//*[@data-testid=\'panel\'][.//*[text()=\'Recent Dashboards\']]//*[text()=\'%TEXT%\']' - -// TODO - add selectors - especially for isLoaded below - -class homePage extends influxPage { - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([//{type: 'css', selector: logoutButton}, - {type: 'xpath', selector: getStartedDataCollect}, - {type: 'xpath', selector: getStartedDashboard}, - {type: 'xpath', selector: getStartedAlerting}, - {type: 'xpath', selector: tutorialsList}, - {type: 'xpath', selector: usefulLinkList}, - ]); - } - - async getLogoutButton(){ - return await this.driver.findElement(By.css(logoutButton)); - } - - async getGetStartedDataCollect(){ - return await this.driver.findElement(By.xpath(getStartedDataCollect)); - } - - async getGetStartedDashboard(){ - return await this.driver.findElement(By.xpath(getStartedDashboard)); - } - - async getGetStartedAlerting(){ - return await this.driver.findElement(By.xpath(getStartedAlerting)); - } - - async getTutorialsList(){ - return await this.driver.findElement(By.xpath(tutorialsList)); - } - - async getUsefulLinksList(){ - return await this.driver.findElement(By.xpath(usefulLinkList)); - } - - async getTutorialLinkByText(text){ - return await this.driver.findElement(By.xpath(`${tutorialsList}//a[text() = '${text}']`)); - } - - async getUsefulLinkByText(text){ - return await this.driver.findElement(By.xpath(`${usefulLinkList}//a[contains(text(), '${text}')]`)); - } - - async getDashboardsList(){ - return await this.driver.findElement(By.xpath(dashboardsList)); - } - - async getDataCollectButton(){ - return await this.driver.findElement(By.css(dataCollectButton)); - } - - async getDashboardButton(){ - return await this.driver.findElement(By.css(dashboardButton)); - } - - async getAlertingButton(){ - return await this.driver.findElement(By.css(alertingButton)); - } - - async getDashboardLink(text){ - return await this.driver.findElement(By.xpath(dashboardLink.replace('%TEXT%', text))); - } -} - -module.exports = homePage; diff --git a/e2e/src/pages/influxPage.js b/e2e/src/pages/influxPage.js deleted file mode 100644 index f9f56160df..0000000000 --- a/e2e/src/pages/influxPage.js +++ /dev/null @@ -1,167 +0,0 @@ -const basePage = require(__srcdir + '/pages/basePage.js'); -const { By } = require('selenium-webdriver'); - -const navMenu = '[data-testid=tree-nav]'; -const navMenuHome = '[data-testid=tree-nav--header]'; -const navMenuDExplorer = '[data-testid=nav-item-data-explorer]'; -const navMenuDashboards = '[data-testid=nav-item-dashboards]'; -const navMenuTasks = '[data-testid=nav-item-tasks]'; -const navMenuAlerting = '[data-testid=nav-item-alerting]'; //N.B. only available with alerting on -const navMenuLoadData = '[data-testid=nav-item-load-data]'; -const navMenuSettings = '[data-testid=nav-item-settings]'; -//const navMenuFeedback = '[data-testid=nav-menu--item] span.nav-chat'; -const navMenuUser = '[data-testid=user-nav]'; -const navMenuOrg = '[data-testid=nav-item-org]'; - -const navMenuHomeHeading = '//a[text() = \'admin (qa)\']'; -const navMenuHomeNewOrg = 'a.cf-nav--sub-item[href=\'/orgs/new\']'; -const navMenuHomeLogout = 'a.cf-nav--sub-item[href=\'/logout\']'; - -const navMenuXpath = '//*[@data-testid = \'nav-menu\']'; -const userMenuItemXpath = '//*[@data-testid = \'user-nav\']'; -const userMenuItem = '[data-testid^=\'user-nav-item-%ITEM%\']'; - -const pageHeader = '[data-testid=page-header]'; - -const urlCtx = 'orgs'; - -class influxPage extends basePage { - - constructor(driver){ - super(driver); - } - - async getNavMenu(){ - return await this.driver.findElement(By.css(navMenu)); - } - - async getPageHeader(page = ''){ - if(page !== ''){ - return await this.driver.findElement(By.css( `[data-testid=${page.toLowerCase()}--header]`)) - } - return await this.driver.findElement(By.css(pageHeader)); - } - - - /* - async isLoaded(){ - await super.isLoaded([{type:'css', selector:navMenu}], urlCtx) - }*/ - - //N.B. Method overloading not supported in JS - however this page is extended - - async isLoaded(selectors = undefined, url = undefined){ - if(!selectors){ - await super.isLoaded([{type:'css', selector:navMenu}, - {type: 'css', selector: navMenuHome}, - {type: 'css', selector: navMenuDExplorer}, - {type: 'css', selector: navMenuDashboards}, - {type: 'css', selector: navMenuTasks}, - //{type: 'css', selector: navMenuAlerting}, //N.B. only available with alerting on - {type: 'css', selector: navMenuLoadData}, - {type: 'css', selector: navMenuSettings}, - {type: 'css', selector: navMenuUser} - // {type: 'css', selector: navMenuOrg}, // TODO - reactivate when certain orgs should be in menu - //TODO - reactivate when pages are stable - // {type: 'css', selector: pageHeader} // 1.7.20 - some pages no longer use generic header e.g. LoadData - ], urlCtx); - return; - } - - if(url){ - await super.isLoaded(selectors.concat([{type: 'css', selector: navMenu}]), url); - // TODO - reactivate when page header refactoring finished - // {type: 'css', selector: pageHeader}]),url); // 1.7.20 - some pages no longer use generic header - }else{ - await super.isLoaded(selectors.concat([{type: 'css', selector: navMenu}]), url); - // TODO - reactivate when page header refactoring finished - //{type: 'css', selector: pageHeader}]), urlCtx); // 1.7.20 - some pages no longer use generic header - } - } - - async getMenuHome(){ - return await this.driver.findElement(By.css(navMenuHome)); - } - - async getMenuExplorer(){ - return await this.driver.findElement(By.css(navMenuDExplorer)); - } - - async getMenuDashboards(){ - return await this.driver.findElement(By.css(navMenuDashboards)); - } - - async getMenuTasks(){ - return await this.driver.findElement(By.css(navMenuTasks)); - } - - /* N.B. only available with alerting enabled - async getMenuAlerting(){ - return await this.driver.findElement(By.css(navMenuAlerting)); - } - */ - - async getMenuLoadData(){ - return await this.driver.findElement(By.css(navMenuLoadData)); - } - - async getMenuSettings(){ - return await this.driver.findElement(By.css(navMenuSettings)); - } - - async getMenuFeedback(){ - return await this.driver.findElement(By.css(navMenuFeedback)); - } - - async getMenuHomeHeading(){ - return await this.driver.findElement(By.xpath(navMenuHomeHeading)); - } - - async getMenuHomeNewOrg(){ - return await this.driver.findElement(By.css(navMenuHomeNewOrg)); - } - - async getMenuHomeLogout(){ - return await this.driver.findElement(By.css(navMenuHomeLogout)); - } - - async getNavMenuAlerting(){ - return await this.driver.findElement(By.css(navMenuAlerting)); - } - - async getSubItemByText(text){ - return await this.driver.findElement(By.xpath(navMenuXpath + `//*[text() = '${text}']`)); - } - - async getSubItemContainingText(text){ - return await this.driver.findElement(By.xpath(navMenuXpath + `//*[contains(text(), '${text}')]`)); - } - - async getNavMenuUser(){ - return await this.driver.findElement(By.css(navMenuUser)); - } - - async getNavMenuOrg(){ - return await this.driver.findElement(By.css(navMenuOrg)); - } - - async getUserMenuSwitchOrg(){ - return await this.driver.findElement(By.xpath( `${userMenuItemXpath}[text() = 'Switch Organizations']`)); - } - - async getUserMenuCreateOrg(){ - return await this.driver.findElement(By.xpath(`${userMenuItemXpath}[text() = 'Create Organization']`)); - } - - async getUserMenuLogout(){ - return await this.driver.findElement(By.xpath(`${userMenuItemXpath}[text() = 'Logout']`)); - } - - async getUserMenuItem(item){ - return await this.driver.findElement(By.css(userMenuItem.replace('%ITEM%', item.toLowerCase()))); - } - - -} - -module.exports = influxPage; diff --git a/e2e/src/pages/loadData/bucketsTab.js b/e2e/src/pages/loadData/bucketsTab.js deleted file mode 100644 index 649c92488f..0000000000 --- a/e2e/src/pages/loadData/bucketsTab.js +++ /dev/null @@ -1,339 +0,0 @@ -const loadDataPage = require(__srcdir + '/pages/loadData/loadDataPage.js'); -const { By } = require('selenium-webdriver'); - -const bucketCards = '[data-testid^=\'bucket--card \']'; -const createBucketBtn = 'button[data-testid=\'Create Bucket\']'; -const filterInput = '[data-testid=search-widget]'; -const nameSorter = '[data-testid=\'name-sorter\']'; -const policySorter = '[data-testid=\'retention-sorter\']'; -const bucketCardByName = '[data-testid=\'bucket--card--name %NAME%\']'; -const bucketCardSettingsByName = `[data-testid='bucket-card %NAME%'] [data-testid=bucket-settings]` - -// Create Bucket Popup -const popupContainer = '[data-testid=overlay--container]'; -const popupTitle = '[data-testid=overlay--header] div'; -const popupInputName = '[data-testid=bucket-form-name]'; -const popupRetentionNever = '[data-testid=retention-never--button]'; -const popupRetentionIntervals = '[data-testid=retention-intervals--button]'; -const popupCancelButton = '[data-testid=overlay--body] button[title=Cancel]'; -const popupDismissButton = '[data-testid=overlay--header] button[class*=dismiss]'; -const popupCreateButton = '[data-testid=overlay--body] button[title*=Create]'; -const popupRPIntervalControls = '[data-testid=form--element] [data-testid=grid--row]'; -const popupRPDurationSelectorButton = '[data-testid=duration-selector--button]'; -const popupRPDaysInput = popupRPIntervalControls + ' [data-testid=grid--column]:nth-of-type(1) input'; -const popupRPHoursInput = popupRPIntervalControls + ' [data-testid=grid--column]:nth-of-type(2) input'; -const popupRPMinutesInput = popupRPIntervalControls + ' [data-testid=grid--column]:nth-of-type(3) input'; -const popupRPSecondsInput = popupRPIntervalControls + ' [data-testid=grid--column]:nth-of-type(4) input'; -const popupFormError = '[data-testid=form--element-error]'; - -//Edit Bucket Popup -const popupSaveChanges = '[data-testid=bucket-form-submit]'; -const popupHelpText = '[data-testid=form--help-text]'; - -//Add data line protocol Popup Wizard -//reuse popup title above -//reuse dismiss above -const wizardStepTitle = '.cf-overlay--title'; -const wizardStepSubTitle = '[data-testid=form-container] [class*=sub-title]'; -const wizardRadioUploadFile = '[data-testid=\'Upload File\']'; -const wizardRadioManual = '[data-testid=\'Enter Manually\']'; -const wizardPrecisionDropdown = '[data-testid=\'wizard-step--lp-precision--dropdown\']'; -const wizardDragAndDrop = 'div.drag-and-drop'; -const wizardContinueButton = '[data-testid=next]'; -const wizardWriteDataButton = '[data-testid*=\'write-data--button\']'; -const wizardTextArea = '[data-testid=\'line-protocol--text-area\']'; -const wizardFinishButton = '[data-testid=next][title=\'Finish\']'; -const wizardCloseButton = '[data-testid=lp-close--button]'; -const wizardCancelButton = '[data-testid^=lp-cancel--button]'; -const wizardDismissButton = '.cf-overlay--dismiss'; -const wizardStepStateText = '[data-testid=\'line-protocol--status\']'; -const wizardSparkleSpinner = '[data-testid=sparkle-spinner]'; -const dataWizardPreviousButton = '[data-testid=overlay--footer] [data-testid=back]'; - -const popoverItem = '//*[@data-testid=\'popover--contents\']//*[text() = \'%ITEM%\']'; - - -const urlCtx = 'buckets'; - -class bucketsTab extends loadDataPage { - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx); - } - - async getBucketCards(){ - return await this.driver.findElements(By.css(bucketCards)); - } - - async getCreateBucketBtn(){ - return await this.driver.findElement(By.css(createBucketBtn)); - } - - async getFilterInput(){ - return await this.driver.findElement(By.css(filterInput)); - } - - async getNameSorter(){ - return await this.driver.findElement(By.css(nameSorter)); - } - - static async getNameSorterSelector(){ - return {type: 'css', selector: nameSorter}; - } - - async getPolicySorter(){ - return await this.driver.findElement(By.css(policySorter)); - } - - //Create Bucket Popup - async getPopupContainer(){ - return await this.driver.findElement(By.css(popupContainer)); - } - - static getPopupContainerSelector(){ - return { type: 'css', selector: popupContainer }; - } - - async getPopupTitle(){ - return await this.driver.findElement(By.css(popupTitle)); - } - - static getPopupTitleSelector(){ - return { type: 'css', selector: popupTitle}; - } - - async getPopupInputName(){ - return await this.driver.findElement(By.css(popupInputName)); - } - - async getPopupRetentionNever(){ - return await this.driver.findElement(By.css(popupRetentionNever)); - } - - async getPopupRetentionIntervals(){ - return await this.driver.findElement(By.css(popupRetentionIntervals)); - } - - async getPopupCancelButton(){ - return await this.driver.findElement(By.css(popupCancelButton)); - } - - async getPopupRPIntevalControls(){ - return await this.driver.findElement(By.css(popupRPIntervalControls)); - } - - static getPopupRPIntervalControlsSelector(){ - return { type: 'css', selector: popupRPIntervalControls }; - } - - async getPopupRPDurationSelectorButton(){ - return await this.driver.findElement(By.css(popupRPDurationSelectorButton)); - } - - static getPopupRPDurationSelectorButtonSelector(){ - return {type: 'css', selector: popupRPDurationSelectorButton}; - } - - async getPopupRPDaysInput(){ - return await this.driver.findElement(By.css(popupRPDaysInput)); - } - - async getPopupRPHoursInput(){ - return await this.driver.findElement(By.css(popupRPHoursInput)); - } - - async getPopupRPMinutesInput(){ - return await this.driver.findElement(By.css(popupRPMinutesInput)); - } - - async getPopupRPSecondsInput(){ - return await this.driver.findElement(By.css(popupRPSecondsInput)); - } - - async getPopupFormError(){ - return await this.driver.findElement(By.css(popupFormError)); - } - - static getPopupFormErrorSelector(){ - return { type: 'css', selector: popupFormError }; - } - - async getPopupDismissButton(){ - //return await this.driver.findElement(By.css(popupDismissButton)); - return await this.smartGetElement({type: 'css', selector: popupDismissButton}); - } - - static async getPopupDismissButtonSelector(){ - return popupDismissButton; - } - - async getPopupRPDurationSelectorItem(duration){ - return await this.driver.findElement(By.css(`[data-testid=duration-selector--${duration}]`)); - } - - async getPopupHelpText(){ - return await this.driver.findElement(By.css(popupHelpText)); - } - - async getPopupCreateButton(){ - return await this.driver.findElement(By.css(popupCreateButton)); - } - - //get just the name link - async getBucketCardName(name){ - return await this.driver.findElement(By.css(`[data-testid='bucket--card--name ${name}']`)); - } - - //get the whole card - async getBucketCardByName(name){ - return await this.driver.findElement(By.css(bucketCardByName.replace('%NAME%', name))); - //return await this.driver.findElement(By.xpath(`//div[div/div[@data-testid='bucket--card ${name}']]`)); - } - - static async getBucketCardDeleteSelectorByName(name){ - return {type: 'xpath', selector: `//div[div/div/div[@data-testid='bucket--card ${name}'] ]//*[@data-testid='context-delete-menu']`}; - } - - async getBucketCardDeleteByName(name){ - // return await this.driver.findElement(By.xpath(`//div[div/div/div[@data-testid='bucket--card ${name}'] ]//*[@data-testid='context-delete-menu']`)); - return await this.driver.findElement(By.css(`[data-testid='context-delete-menu ${name}']`)); - } - - async getBucketCardRetentionByName(name){ - // return await this.driver.findElement(By.xpath(`//div[div/div[@data-testid='bucket--card ${name}']]//div[contains(text(), 'Retention')]`)); - //return await this.driver.findElement(By.xpath(`//*[@data-testid='bucket--card ${name}']//*[@data-testid='cf-resource-card--meta-item'][contains(text(),"Retention")]`)); - //return await this.driver.findElement(By.xpath(`//*[@data-testid='bucket-card'][.//*[@data-testid='bucket--card--name ${name}']]//*[@data-testid='cf-resource-card--meta-item'][contains(text(), 'Retention')]`)); - return await this.driver.findElement(By.xpath(`//*[@data-testid='bucket-card ${name}']//*[@data-testid='resource-list--meta']//*[contains(text(), 'Retention')]`)); - } - - async getBucketCardPopover(){ - //return await this.driver.findElement(By.xpath(`//div[div/div[@data-testid='bucket--card ${name}']]//div[@data-testid='popover--contents']`)); - return await this.driver.findElement(By.css('[data-testid=popover--contents]')); - } - - static async getPopoverSelector(){ - return { type: 'css', selector: '[data-testid=popover--contents]'}; - } - - async getBucketCardPopoverItemByName(name, item){ - return await this.driver.findElement(By.xpath(`//div[div/div[@data-testid='bucket--card ${name}']]//div[@data-testid='popover--contents']//div[contains(text(), '${item}')]`)); - } - - static async getBucketCardSelectorByName(name){ - return {type: 'css', selector: `[data-testid='bucket--card ${name}']`}; - } - - async getBucketCardDeleteConfirmByName(name){ - //return await this.smartGetElement({type: 'xpath', selector: `//div[div/div/div[@data-testid='bucket--card ${name}'] ]//*[@data-testid='context-delete-menu']/..//button[text() = 'Confirm']`}); - //return await this.driver.findElement(By.xpath(`//div[div/div/div[@data-testid='bucket--card ${name}'] ]//*[@data-testid='context-delete-menu']/..//button[text() = 'Confirm']`)); - return await this.driver.findElement(By.css(`[data-testid='context-delete-bucket ${name}'] `)); - } - - async getBucketCardAddDataByName(name){ - - //return await this.driver.findElement(By.xpath(`//*[@data-testid='bucket-card'][.//*[@data-testid='bucket--card--name ${name}']]//button[@title='Add Data']`)); - return await this.driver.findElement(By.xpath(`//*[@data-testid='bucket-card ${name}']//button[@title='Add Data']`)) - //return await this.smartGetElement({type: 'xpath', selector: `//div[div/div/div[@data-testid='bucket--card ${name}']]//button[@title = 'Add Data']`}); - } - - async getPopupSaveChanges(){ - return await this.driver.findElement(By.css(popupSaveChanges)); - } - - async getWizardStepTitle(){ - return await this.driver.findElement(By.css(wizardStepTitle)); - } - - static async getWizardStepTitleSelector(){ - return {type: 'css', selector: wizardStepTitle }; - } - - async getWizardStepSubTitle(){ - return await this.driver.findElement(By.css(wizardStepSubTitle)); - } - - static async getWizardStepSubTitleSelector(){ - return {type: 'css', selector: wizardStepSubTitle }; - } - - - async getWizardRadioUploadFile(){ - return await this.driver.findElement(By.css(wizardRadioUploadFile)); - } - - async getWizardRadioManual(){ - return await this.driver.findElement(By.css(wizardRadioManual)); - } - - async getWizardPrecisionDropdown(){ - return await this.driver.findElement(By.css(wizardPrecisionDropdown)); - } - - async getWizardDragAndDrop(){ - return await this.driver.findElement(By.css(wizardDragAndDrop)); - } - - async getWizardContinueButton(){ - return await this.driver.findElement(By.css(wizardContinueButton)); - } - - static async getWizardContinueButtonSelector(){ - return {type: 'css', selector: wizardContinueButton }; - } - - async getWizardWriteDataButton(){ - return await this.driver.findElement(By.css(wizardWriteDataButton)); - } - - - async getWizardTextArea(){ - return await this.driver.findElement(By.css(wizardTextArea)); - } - - async getWizardDropdownPrecisionItem(prec){ - return await this.driver.findElement(By.css(`[data-testid='wizard-step--lp-precision-${prec}']`)); - } - - async getWizardFinishButton(){ - return await this.driver.findElement(By.css(wizardFinishButton)); - } - - async getWizardCloseButton(){ - return await this.driver.findElement(By.css(wizardCloseButton)); - } - - async getWizardCancelButton(){ - return await this.driver.findElement(By.css(wizardCancelButton)); - } - - async getWizardDismissButton(){ - return await this.driver.findElement(By.css(wizardDismissButton)); - } - - async getWizardStepStateText(){ - return await this.driver.findElement(By.css(wizardStepStateText)); - } - - async getWizardSparkleSpinner(){ - return await this.driver.findElement(By.css(wizardSparkleSpinner)); - } - - async getPopoverItem(item){ - return await this.driver.findElement(By.xpath(popoverItem.replace('%ITEM%', item))); - } - - async getDataWizardPreviousButton(){ - return await this.driver.findElement(By.css(dataWizardPreviousButton)); - } - - async getBucketCardSettingsByName(name){ - return await this.driver.findElement(By.css(bucketCardSettingsByName.replace('%NAME%', name))); - } - -} - -module.exports = bucketsTab; diff --git a/e2e/src/pages/loadData/clientLibsTab.js b/e2e/src/pages/loadData/clientLibsTab.js deleted file mode 100644 index c0d6aabc99..0000000000 --- a/e2e/src/pages/loadData/clientLibsTab.js +++ /dev/null @@ -1,43 +0,0 @@ -const { By } = require('selenium-webdriver'); -const loadDataPage = require(__srcdir + '/pages/loadData/loadDataPage.js'); - -const libTileByName = '[data-testid=\'client-libraries-cards--%NAME%\']'; -const clientURL = '[data-testid=tabs--tab-contents] .code-snippet code'; -const copy2ClipByLabel = '//*[text() = \'%LABEL%\']/following-sibling::div[1]//button'; - - -const urlCtx = 'client-libraries'; - -class clientLibsTab extends loadDataPage { - - constructor(driver) { - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: clientURL}, - {type: 'css', selector: libTileByName.replace('%NAME%', 'csharp')}, - {type: 'css', selector: libTileByName.replace('%NAME%', 'java')}, - {type: 'css', selector: libTileByName.replace('%NAME%', 'python')}, - ] - ); - } - - - async getLibTileByName(name){ - return await this.driver.findElement(By.css(libTileByName.replace('%NAME%', name))); - } - - async getClientURL(){ - return await this.driver.findElement(By.css(clientURL)); - } - - async getCopy2ClipByLabel(label){ - return await this.driver.findElement(By.xpath(copy2ClipByLabel.replace('%LABEL%', label))); - } - -} - -module.exports = clientLibsTab; diff --git a/e2e/src/pages/loadData/loadDataPage.js b/e2e/src/pages/loadData/loadDataPage.js deleted file mode 100644 index a94654fda6..0000000000 --- a/e2e/src/pages/loadData/loadDataPage.js +++ /dev/null @@ -1,146 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const tabsCss = '[data-testid=tabs]'; -const tabsXpath = '//*[@data-testid=\'tabs\']'; -const pageTitle = '[data-testid=\'page-title\']'; - -const urlCtx = 'settings'; - -//Create Scraper Popup - accessible in both Scraper Page and base LoadData page - through buckets add data -const createScraperTitle = '[data-testid=overlay--header] [class*=title]'; -const createScraperDismiss = '[data-testid=overlay--header] button'; -const createScraperNameInput = '[data-testid=input-field][title=Name]'; -const createScraperBucketDropdown = '[data-testid=bucket-dropdown--button]'; -const createScraperUrlInput = '[data-testid=input-field][title*=URL]'; -const createScraperCancel = '[data-testid=create-scraper--cancel]'; -const createScraperSubmit = '[data-testid=create-scraper--submit]'; -const createScraperBucketDropdownItems = '[data-testid=bucket-dropdown] [data-testid=dropdown-item]'; - -//Create Telegraf Config Wizard - accessible from buckets and telegraf -const bucketDropdown = '[data-testid=bucket-dropdown]'; -const pluginsFilter = '[data-testid=input-field][placeholder*=Plugins]'; -const telegrafNameInput = '[data-testid=input-field][title$=\'Name\']'; -const telegrafDescrInput = '[data-testid=input-field][title$=\'Description\']'; -//common controls in basePage -const codeSnippetWithToken = 'div.code-snippet:first-of-type'; -const codeSnippetWithTelegrafCommand = 'div.code-snippet:nth-of-type(2)'; - - -class loadDataPage extends influxPage { - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: tabsCss}], urlCtx); - } - - async isTabLoaded(tabUrlPart, selectors = undefined){ - if(selectors) { - await super.isLoaded(selectors.concat([{type: 'css', selector: tabsCss}]), tabUrlPart); - }else{ - await super.isLoaded([{type: 'css', selector: tabsCss}], tabUrlPart); - } - } - - async getTabByName(name){ - return await this.driver.findElement(By.xpath(`${tabsXpath}//div[@data-testid='tabs--tab' and @id='${name.toLowerCase().replace(' ', '-')}']`)); - } - - async getPageTitle(){ - return await this.driver.findElement(By.css(pageTitle)); - } - - //Create Scraper Popup - async getCreateScraperTitle(){ - return await this.driver.findElement(By.css(createScraperTitle)); - } - - static getCreateScraperTitleSelector(){ - return { type: 'css', selector: createScraperTitle}; - } - - async getCreateScraperDismiss(){ - return await this.driver.findElement(By.css(createScraperDismiss)); - } - - async getCreateScraperNameInput(){ - return await this.driver.findElement(By.css(createScraperNameInput)); - } - - static getCreateScraperNameInputSelector(){ - return { type: 'css', selector: createScraperNameInput}; - } - - async getCreateScraperBucketDropdown(){ - return await this.driver.findElement(By.css(createScraperBucketDropdown)); - } - - async getCreateScraperUrlInput(){ - return await this.driver.findElement(By.css(createScraperUrlInput)); - } - - static getCreateScraperUrlInputSelector(){ - return { type: 'css', selector: createScraperUrlInput}; - } - - async getCreateScraperCancel(){ - return await this.driver.findElement(By.css(createScraperCancel)); - } - - async getCreateScraperSubmit(){ - return await this.driver.findElement(By.css(createScraperSubmit)); - } - - async getCreateScraperBucketDropdownItem(item){ - return await this.driver.findElement(By.xpath(`//*[@data-testid='dropdown-item']/div[text() = '${item}']`)); - } - - static getCreateScraperBucketDropdownItemSelector(item){ - return `//*[@data-testid='dropdown-item']/div[text() = '${item}']`; - } - - static getCreateScraperBucketDropdownItemsSelector(){ - return {type: 'css', selector: createScraperBucketDropdownItems}; - } - - //Create telegraf wizard - async getBucketDropdown(){ - return await this.driver.findElement(By.css(bucketDropdown)); - } - - async getPluginsFilter(){ - return await this.driver.findElement(By.css(pluginsFilter)); - } - - async getPluginTileByName(name){ - return await this.driver.findElement(By.css(`[data-testid=telegraf-plugins--${name}]`)); - } - - async getBucketDropdownItem(item){ - return await this.driver.findElement( - By.xpath(`//*[@data-testid='dropdown-item'][div[text()='${item}']]`)); - } - - async getTelegrafNameInput(){ - return await this.driver.findElement(By.css(telegrafNameInput)); - } - - async getTelegrafDescrInput(){ - return await this.driver.findElement(By.css(telegrafDescrInput)); - } - - async getCodeSnippetWithToken(){ - return await this.driver.findElement(By.css(codeSnippetWithToken)); - } - - async getCodeSnippetWithTelegrafCommand(){ - return await this.driver.findElement(By.css(codeSnippetWithTelegrafCommand)); - } - - -} - -module.exports = loadDataPage; diff --git a/e2e/src/pages/loadData/scrapersTab.js b/e2e/src/pages/loadData/scrapersTab.js deleted file mode 100644 index 530599d9d4..0000000000 --- a/e2e/src/pages/loadData/scrapersTab.js +++ /dev/null @@ -1,93 +0,0 @@ -const { By } = require('selenium-webdriver'); -const loadDataPage = require(__srcdir + '/pages/loadData/loadDataPage.js'); -const basePage = require(__srcdir + '/pages/basePage.js'); - -const scrapersFilter = '[data-testid=search-widget]'; -const createScraperHeader = '[data-testid=create-scraper-button-header]'; -const nameSort = '[data-testid=resource-list--sorter]:nth-of-type(1)'; -const urlSort = '[data-testid=resource-list--sorter]:nth-of-type(2)'; -const bucketSort = '[data-testid=resource-list--sorter]:nth-of-type(3)'; -const createScraperEmpty = '[data-testid=create-scraper-button-empty]'; -const scraperCards = '[data-testid=resource-card]'; - -const urlCtx = 'scrapers'; - -class scrapersTab extends loadDataPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: scrapersFilter}, - {type: 'css', selector: createScraperHeader}, - basePage.getSortTypeButtonSelector() - //{type: 'css', selector: nameSort}, - //{type: 'css', selector: urlSort}, - //{type: 'css', selector: bucketSort}, - ] - ); - } - - async getScraperCardByName(name){ - return await this.driver.findElement(By.xpath(`//*[@data-testid='resource-card'][//span[text() = '${name}']]`)); - } - - async getScraperCardName(name){ - return await this.driver.findElement(By.xpath(`//*[@data-testid='resource-editable-name']//span[text()='${name}']`)); - } - - async getScraperCardNameEditButton(name){ - return await this.driver.findElement(By.xpath(`//*[./*[@data-testid='resource-editable-name'][.//span[text()='${name}']]]//*[@data-testid='editable-name']`)); - } - - async getScraperCardNameEditField(name){ - return await this.driver.findElement(By.xpath(`//*[@data-testid='input-field'][@value='${name}']`)); - } - - async getScraperCardDeleteByName(name){ - return await this.driver.findElement(By.xpath(`//*[@data-testid='resource-card'][.//span[text()='${name}']]//*[@data-testid='context-menu']`)); - } - - async getScraperCardDeleteConfirmByName(name){ - return await this.driver.findElement(By.xpath(`//*[@data-testid='resource-card'][.//span[text()='${name}']]//*[@data-testid='confirmation-button']`)); - } - - async getScrapersFilter(){ - return this.driver.findElement(By.css(scrapersFilter)); - } - - async getCreateScraperHeader(){ - return this.driver.findElement(By.css(createScraperHeader)); - } - - async getNameSort(){ - return this.driver.findElement(By.css(nameSort)); - } - - async getUrlSort(){ - return this.driver.findElement(By.css(urlSort)); - } - - async getBucketSort(){ - return this.driver.findElement(By.css(bucketSort)); - } - - async getCreateScraperEmpty(){ - return this.driver.findElement(By.css(createScraperEmpty)); - } - - static getCreateScraperEmptySelector(){ - return { type: 'css', selector: createScraperEmpty}; - } - - async getScraperCards(){ - return await this.driver.findElements(By.css(scraperCards)); - } - - -} - -module.exports = scrapersTab; diff --git a/e2e/src/pages/loadData/telegrafsTab.js b/e2e/src/pages/loadData/telegrafsTab.js deleted file mode 100644 index e9cacdf953..0000000000 --- a/e2e/src/pages/loadData/telegrafsTab.js +++ /dev/null @@ -1,317 +0,0 @@ -const { By } = require('selenium-webdriver'); -const loadDataPage = require(__srcdir + '/pages/loadData/loadDataPage.js'); -const basePage = require(__srcdir + '/pages/basePage.js'); - -const telegrafsFilter = '[data-testid=search-widget]'; -const createConfigInHeader = '//div[@data-testid=\'tabbed-page--header\']//*[contains(@title, \'Create\')]'; -const nameSort = '[data-testid=name-sorter]'; -const bucketSort = '[data-testid=bucket-sorter]'; -const createConfigInBody = '[data-testid=resource-list] [data-testid=button]'; -const telegrafCardTemplate = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]'; -const telegrafCards = '[data-testid=resource-card]'; -const telegrafCardSetupInstructions = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'setup-instructions-link\']'; -const telegrafCardName = '//*[@data-testid=\'collector-card--name\'][span[text()=\'%NAME%\']]'; -const telegrafCardNameEditBtn = '//*[./*[@data-testid=\'collector-card--name\'][span[text()=\'%NAME%\']]]//*[@data-testid=\'collector-card--name-button\']'; -const telegrafCardNameInput = '[data-testid=\'collector-card--input\']'; //should only be one active -const telegrafCardDescr = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'resource-list--editable-description\']'; -const telegrafCardDescrEditBtn = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'resource-list--editable-description\']//*[@data-testid=\'icon\']'; -const telegrafCardDescrInput = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//div[@data-testid=\'resource-list--editable-description\']//input'; -const telegrafCardDelete = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'telegraf-delete-menu\']'; -const telegrafCardDeleteConfirm = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//button[@data-testid=\'telegraf-delete-button\']'; -const telegrafCardAddLabelBtn = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'inline-labels--add\']'; -const telegrafCardLabelPopup = '[data-testid=inline-labels--popover--dialog]'; -const telegrafCardLabelPopupListItem = '[data-testid=\'inline-labels--popover--dialog\'] [data-testid=\'label-list--item %ITEM%\']'; -const telegrafCardLabelPillItem = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'label--pill %ITEM%\']'; -const telegrafCardLabelPopupFilter = '[data-testid=\'inline-labels--popover--dialog\'] [data-testid=\'inline-labels--popover-field\']'; -const telegrafCardLabelEmptyState = '[data-testid=\'inline-labels--popover--dialog\'] [data-testid=\'empty-state--text\']'; -const telegrafCardLabelPillDelete = '//*[@data-testid=\'resource-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'label--pill--delete %ITEM%\']'; - -const urlCtx = 'telegrafs'; - -// Telegraf wizard -const bucketDropdownBtn = '[data-testid=bucket-dropdown--button] '; -const pluginFilter = '[data-testid=input-field][placeholder*=\'Plugins\']'; -const pluginTileTemplate = '[data-testid=telegraf-plugins--%TILE_NAME%]'; - -// Telegraf wizard step 2 -const configurationNameInput = '[data-testid=input-field][title*=\'Configuration Name\']'; -const configurationDescrInput = '[data-testid=input-field][title*=\'Configuration Descr\']'; -const configurationPluginsSideBar = '//*[*[text()=\'Plugins\']]//div[contains(@class,\'side-bar--tabs\')]'; - -//Telegraf wizard edit plugin -const pluginDockerEditEndpoint = '//*[.//*[text()=\'endpoint\']][@data-testid=\'form--element\']//*[@data-testid=\'input-field\']'; -const pluginK8SEditEndpoint = '//*[.//*[text()=\'url\']][@data-testid=\'form--element\']//*[@data-testid=\'input-field\']'; -const pluginNGINXEditEndpoint = '//*[.//*[text()=\'urls\']][@data-testid=\'form--element\']//*[@data-testid=\'input-field\']'; -const pluginNGINXAddUrlButton = '[data-testid=button][title=\'Add to list of urls\']'; -const pluginNGINXDeleteFirstURL = '[data-testid=confirmation-button--button][title=\'Delete\']:nth-of-type(1)'; -const pluginNGINXDeleteURLConfirmButton = '[data-testid=confirmation-button--confirm-button]'; -const pluginNGINXURLListItems = '[data-testid=overlay--body] [data-testid=\'grid--column\'] [data-testid=index-list]'; -const pluginRedisServersEditEndpoint = '//*[.//*[text()=\'servers\']][@data-testid=\'form--element\']//*[@data-testid=\'input-field\']'; -const pluginRedisPasswordEditEndpoint = '//*[.//*[text()=\'password\']][@data-testid=\'form--element\']//*[@data-testid=\'input-field\']'; - -//Telegraf wizard step 3 -const codeToken = '//pre[contains(text(), \'TOKEN\')]'; -const codeCliTelegraf = '//code[contains(text(), \'telegraf\')]'; -const copyToClipboardToken = '//*[@class=\'code-snippet\'][.//*[contains(text(),\'TOKEN\')]]//*[@data-testid=\'button-copy\']'; -const copyToClipboardCommand = '//*[@class=\'code-snippet\'][.//*[contains(text(),\'telegraf\')]]//*[@data-testid=\'button-copy\']'; - -//Config Popup -const downloadConfigButton = '//*[@data-testid=\'button\'][span[text()=\'Download Config\']]'; - - - -class telegrafsTab extends loadDataPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: telegrafsFilter}, - {type: 'xpath', selector: createConfigInHeader}, - //{type: 'css', selector: nameSort}, - basePage.getSortTypeButtonSelector() - //{type: 'css', selector: bucketSort}, - ] - ); - } - - async getTelegraphCardByName(name){ - return await this.driver.findElement(By.xpath(`//*[@data-testid='resource-card'][//span[text()='${name}']]`)); - } - - async getTelegrafsFilter(){ - return await this.driver.findElement(By.css(telegrafsFilter)); - } - - async getCreateConfigInHeader(){ - return await this.driver.findElement(By.xpath(createConfigInHeader)); - } - - async getNameSort(){ - return await this.driver.findElement(By.css(nameSort)); - } - - async getBucketSort(){ - return await this.driver.findElement(By.css(bucketSort)); - } - - async getCreateConfigInBody(){ - return await this.driver.findElement(By.css(createConfigInBody)); - } - - // Telegraf Wizard - - async getBucketDropdownBtn(){ - return await this.driver.findElement(By.css(bucketDropdownBtn)); - } - - async getPluginFilter(){ - return await this.driver.findElement(By.css(pluginFilter)); - } - - async getPluginTileByName(name){ - return await this.driver.findElement(By.css(pluginTileTemplate.replace('%TILE_NAME%', name))); - } - - static getPluginTitleSelectorByName(name){ - return { type: 'css', selector: pluginTileTemplate.replace('%TILE_NAME%', name)}; - } - - // Telegraf Wizard step 2 - async getPluginItemByName(name){ - return await this.driver.findElement(By.xpath(`//*[contains(@class, 'side-bar--tab')]/div[.//*[text() = '${name.toLowerCase()}']]`)); - } - - async getConfigurationNameInput(){ - return await this.driver.findElement(By.css(configurationNameInput)); - } - - static getConfigurationNameInputSelector(){ - return { type: 'css', selector: configurationNameInput}; - } - - async getConfigurationDescrInput(){ - return await this.driver.findElement(By.css(configurationDescrInput)); - } - - static getConfigurationDescrInputSelector(){ - return { type: 'css', selector: configurationDescrInput}; - } - - async getConfigurationPluginsSideBar(){ - return await this.driver.findElement(By.xpath(configurationPluginsSideBar)); - } - - static configurationPluginsSideBarSelector(){ - return { type: 'css', selector: configurationPluginsSideBar}; - } - - //Telegraf wizard edit plugin - async getPluginDockerEditEndpoint(){ - return await this.driver.findElement(By.xpath(pluginDockerEditEndpoint)); - } - - async getPluginK8SEditEndpoint(){ - return await this.driver.findElement(By.xpath(pluginK8SEditEndpoint)); - } - - async getPluginNGINXEditEndpoint(){ - return await this.driver.findElement(By.xpath(pluginNGINXEditEndpoint)); - } - - async getPluginNGINXAddUrlButton(){ - return await this.driver.findElement(By.css(pluginNGINXAddUrlButton)); - } - - async getPluginNGINXDeleteFirstURL(){ - return await this.driver.findElement(By.css(pluginNGINXDeleteFirstURL)); - } - - async getPluginNGINXDeleteURLConfirmButton(){ - return await this.driver.findElement(By.css(pluginNGINXDeleteURLConfirmButton)); - } - - async getPluginNGINXURLListItems(){ - return await this.driver.findElements(By.css(pluginNGINXURLListItems)); - } - - static getPluginNGINXURLListItemsSelector(){ - return { type: 'css', selector: pluginNGINXURLListItems }; - } - - async getPluginRedisServersEditEndpoint(){ - return await this.driver.findElement(By.xpath(pluginRedisServersEditEndpoint)); - } - - async getPluginRedisPasswordEditEndpoint(){ - return await this.driver.findElement(By.xpath(pluginRedisPasswordEditEndpoint)); - } - - async getCodeToken(){ - return await this.driver.findElement(By.xpath(codeToken)); - } - - async getCodeCliTelegraf(){ - return await this.driver.findElement(By.xpath(codeCliTelegraf)); - } - - // Config popup - - async getDownloadConfigButton(){ - return await this.driver.findElement(By.xpath(downloadConfigButton)); - } - - // Telegraf Card List - - async getTelegrafCardByName(name){ - return await this.driver.findElement(By.xpath(telegrafCardTemplate.replace('%NAME%', name))); - } - - static getTelegrafCardSelectorByName(name){ - return { type: 'xpath', selector: telegrafCardTemplate.replace('%NAME%', name) }; - } - - async getTelegrafCards(){ - return await this.driver.findElements(By.css(telegrafCards)); - } - - async getCopyToClipboardToken(){ - return await this.driver.findElement(By.xpath(copyToClipboardToken)); - } - - async getCopyToClipboardCommand(){ - return await this.driver.findElement(By.xpath(copyToClipboardCommand)); - } - - async getTelegrafCardSetupInstructions(card){ - return await this.driver.findElement(By.xpath(telegrafCardSetupInstructions.replace('%NAME%', card))); - } - - async getTelegrafCardName(name){ - return await this.driver.findElement(By.xpath(telegrafCardName.replace('%NAME%', name))); - } - - async getTelegrafCardNameEditBtn(name){ - return await this.driver.findElement(By.xpath(telegrafCardNameEditBtn.replace('%NAME%', name))); - } - - async getTelegrafCardNameInput(name){ - return await this.driver.findElement(By.css(telegrafCardNameInput.replace('%NAME%', name))); - } - - async getTelegrafCardDescr(name){ - return await this.driver.findElement(By.xpath(telegrafCardDescr.replace('%NAME%', name))); - } - - async getTelegrafCardDescrEditBtn(name){ - return await this.driver.findElement(By.xpath(telegrafCardDescrEditBtn.replace('%NAME%', name))); - } - - async getTelegrafCardDescrInput(name){ - return await this.driver.findElement(By.xpath(telegrafCardDescrInput.replace('%NAME%', name))); - } - - async getTelegrafCardDelete(name){ - return await this.driver.findElement(By.xpath(telegrafCardDelete.replace('%NAME%', name))); - } - - async getTelegrafCardDeleteConfirm(name){ - return await this.driver.findElement(By.xpath(telegrafCardDeleteConfirm.replace('%NAME%', name))); - } - - async getTelegrafCardAddLabelBtn(name){ - return await this.driver.findElement(By.xpath(telegrafCardAddLabelBtn.replace('%NAME%', name))); - } - - async getTelegrafCardLabelPopup(name){ - return await this.driver.findElement(By.css(telegrafCardLabelPopup.replace('%NAME%', name))); - } - - static getTelegrafCardLabelPopupSelector(name){ - return { type: 'css', selector: telegrafCardLabelPopup.replace('%NAME%', name)}; - } - - async getTelegrafCardLabelPopupListItem(name, item){ - - return await this.driver.findElement(By.css(telegrafCardLabelPopupListItem - .replace('%ITEM%', item))); - - } - - static getTelegrafCardLabelPopupListItemSelector(name, item){ - return { type: 'css', selector: telegrafCardLabelPopupListItem - .replace('%ITEM%', item)}; - } - - async getTelegrafCardLabelPillItem(name, item){ - return await this.driver.findElement(By.xpath(telegrafCardLabelPillItem - .replace('%NAME%', name) - .replace('%ITEM%', item))); - } - - static getTelegrafCardLabelPillItemSelector(name, item){ - return { type: 'xpath', selector: telegrafCardLabelPillItem - .replace('%NAME%', name) - .replace('%ITEM%', item)}; - } - - async getTelegrafCardLabelPopupFilter(name){ - return await this.driver.findElement(By.css(telegrafCardLabelPopupFilter.replace('%NAME%', name))); - } - - async getTelegrafCardLabelEmptyState(name){ - return await this.driver.findElement(By.css(telegrafCardLabelEmptyState.replace('%NAME%', name))); - } - - async getTelegrafCardLabelPillDelete(name, item){ - return await this.driver.findElement(By.xpath(telegrafCardLabelPillDelete - .replace('%NAME%', name) - .replace('%ITEM%', item))); - } - -} - -module.exports = telegrafsTab; diff --git a/e2e/src/pages/loadData/tokensTab.js b/e2e/src/pages/loadData/tokensTab.js deleted file mode 100644 index ed931eaeff..0000000000 --- a/e2e/src/pages/loadData/tokensTab.js +++ /dev/null @@ -1,196 +0,0 @@ -const { By } = require('selenium-webdriver'); -const settingsPage = require(__srcdir + '/pages/settings/settingsPage.js'); - -const tokensFilter = '[data-testid=input-field--filter]'; -const genTokenButton = '[data-testid=dropdown-button--gen-token]'; -const tokenListing = '[data-testid=resource-list]'; -//const descHeader = '[data-testid=index-list--header-cell]:nth-of-type(1)';// header no longer present 10.6 -//const statusHeader = '[data-testid=index-list--header-cell]:nth-of-type(2)'; //header no longer present 10.6 -//const createVariableBody = '[data-testid=button-create-initial]'; -const tokenCellTemplate = '[data-testid="token-card %DESCR%"]'; -const generateTokenDropdownBtn = '[data-testid=dropdown-button--gen-token]'; -const generateTokenItem = '[data-testid=\'dropdown-item generate-token--%ITEM%\']'; -const tokenCardDisableToggle = '[data-testid = \'token-card %DESCR%\'] [data-testid=\'slide-toggle\']'; -const tokenSorterButton = '[data-testid=resource-sorter--button]'; -const tokenSorterItem = '[data-testid=resource-sorter--%ITEM%]'; -const tokensSortByDescription = '//*[@data-testid=\'index-list--header-cell\'][text()=\'Description\']'; -const tokenDescription = '[data-testid=\'token-name %DESCR%\']'; -const tokenDescriptionEditBtn = '[data-testid=\'token-card %DESCR%\'] [data-testid=\'resource-editable-name--button\']'; -const tokenDescriptionEditInput = '//*[./*[@data-testid=\'resource-editable-name--input--default\']]/input'; -const tokenCardDeleteButton = '[data-testid=\'token-card %DESCR%\'] [data-testid=\'context-menu\']'; -// next selector is deprecated - todo clean up -const tokenCardDeleteConfirm = '[data-testid=\'token-card %DESCR%\'] [data-testid=\'delete-token\']'; -const tokenCardPopoverDeletConfirm = '//*[@data-testid=\'delete-token--popover--dialog\']//*[text() = \'Confirm\']'; - -// Generate Read/Write token popup -const descrInput = '[data-testid=\'input-field--descr\']'; -const typeRadioButton = '//*[@data-testid=\'flex-box\'][div[text()=\'%MODE%\']]//*[@data-testid=\'select-group--option\'][@title=\'%SET%\']'; -const searchBuckets = '//*[@data-testid=\'flex-box\'][div[text()=\'%MODE%\']]//input[@data-testid=\'input-field\'][contains(@placeholder,\'Search buckets\')]'; -const emptyStateText = '//*[@data-testid=\'flex-box\'][div[text()=\'%MODE%\']]//*[@data-testid=\'empty-state--text\']'; -const searchBucketsListItem = '//*[@data-testid=\'flex-box\'][div[text()=\'%MODE%\']]//*[@data-testid=\'selector-list %NAME%\']'; -const selectAllBuckets = '//*[@data-testid=\'flex-box\'][div[text()=\'%MODE%\']]//*[@title=\'Select All\']'; -const deselectAllBuckets = '//*[@data-testid=\'flex-box\'][div[text()=\'%MODE%\']]//*[@title=\'Deselect All\']'; - -//Generate All Access token popup -const allAccessDescrInput = '[data-testid=all-access-token-input]'; -const allAccessCancelButton = '[data-testid=button][title=Cancel]'; -const allAccessSaveButton = '[data-testid=button--save]'; - -//Review token popup -const tokenReviewTokenCode = 'div.code-snippet--text pre code'; -const tokenReviewPermissions = '[data-testid=permissions-section]'; -const tokenReviewPermissionItem = '//*[@data-testid=\'permissions-section\'][.//h3[text()=\'%ITEM%\']]'; - - -const urlCtx = 'tokens'; - -class tokensTab extends settingsPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: tokensFilter}, - {type: 'css', selector: genTokenButton}, - {type: 'css', selector: tokenListing}, - {type: 'css', selector: tokenSorterButton} - ] - ); - } - - async getTokenCellByDescr(descr){ - return await this.driver.findElement(By.css(tokenCellTemplate.replace('%DESCR%', descr))); - } - - static getTokenCellSelectorByDescr(descr){ - return { type: 'css', selector: tokenCellTemplate.replace('%DESCR%', descr)}; - } - - async getGenerateTokenDropdownBtn(){ - return await this.driver.findElement(By.css(generateTokenDropdownBtn)); - } - - async getGenerateTokenItem(item){ - return await this.driver.findElement(By.css(generateTokenItem.replace('%ITEM%', item))); - } - - async getDescrInput(){ - return await this.driver.findElement(By.css(descrInput)); - } - - async getTypeRadioButton(mode, set){ - return await this.driver.findElement(By.xpath(typeRadioButton - .replace('%MODE%',mode) - .replace('%SET%',set))); - } - - async getSearchBuckets(mode){ - return await this.driver.findElement(By.xpath(searchBuckets.replace('%MODE%', mode))); - } - - static getSearchBucketsSelector(mode){ - return { type: 'xpath', selector: searchBuckets.replace('%MODE%', mode) }; - } - - async getEmptyStateText(mode){ - return await this.driver.findElement(By.xpath(emptyStateText.replace('%MODE%', mode))); - } - - static getEmptyStateTextSelector(mode){ - return { type: 'xpath', selector: emptyStateText.replace('%MODE%', mode) }; - } - - async getSearchBucketsListItem(mode, name){ - return await this.driver.findElement(By.xpath(searchBucketsListItem - .replace('%MODE%', mode) - .replace('%NAME%', name))); - } - - static getSearchBucketsListItemSelector(mode, name){ - return { type: 'xpath', selector: searchBucketsListItem - .replace('%MODE%', mode) - .replace('%NAME%', name)}; - } - - async getSelectAllBuckets(mode){ - return await this.driver.findElement(By.xpath(selectAllBuckets.replace('%MODE%', mode))); - } - - async getDeselectAllBuckets(mode){ - return await this.driver.findElement(By.xpath(deselectAllBuckets.replace('%MODE%', mode))); - } - - async getAllAccessDescrInput(){ - return await this.driver.findElement(By.css(allAccessDescrInput)); - } - - async getAllAccessCancelButton(){ - return await this.driver.findElement(By.css(allAccessCancelButton)); - } - - async getAllAccessSaveButton(){ - return await this.driver.findElement(By.css(allAccessSaveButton)); - } - - async getTokenCardDisableToggle(descr){ - return await this.driver.findElement(By.css(tokenCardDisableToggle.replace('%DESCR%', descr))); - } - - async getTokenCardDescriptions(){ - return await this.driver.findElements(By.css('[data-testid^="token-name"]')); - } - - async getTokenSorterButton(){ - return await this.driver.findElement(By.css(tokenSorterButton)); - } - - async getTokenSorterItem(item){ - return await this.driver.findElement(By.css(tokenSorterItem.replace('%ITEM%', - item.toLowerCase().replace(' ','-')))); - } - - async getTokensSortByDescription(){ - return await this.driver.findElement(By.xpath(tokensSortByDescription)); - } - - async getTokenDescription(descr){ - return await this.driver.findElement(By.css(tokenDescription.replace('%DESCR%', descr))); - } - - async getTokenDescriptionEditBtn(descr){ - return await this.driver.findElement(By.css(tokenDescriptionEditBtn.replace('%DESCR%', descr))); - } - - async getTokenDescriptionEditInput(descr){ - return await this.driver.findElement(By.xpath(tokenDescriptionEditInput)); - } - - async getTokenReviewTokenCode(){ - return await this.driver.findElement(By.css(tokenReviewTokenCode)); - } - - async getTokenReviewPermissions(){ - return await this.driver.findElement(By.css(tokenReviewPermissions)); - } - - async getTokenReviewPermissionItem(item){ - return await this.driver.findElement(By.xpath(tokenReviewPermissionItem.replace('%ITEM%', item))); - } - - async getTokenCardDeleteButton(descr){ - return await this.driver.findElement(By.css(tokenCardDeleteButton.replace('%DESCR%', descr))); - } - - async getTokenCardDeleteConfirm(descr){ - return await this.driver.findElement(By.css(tokenCardDeleteConfirm.replace('%DESCR%', descr))); - } - - async getTokenCardPopoverDeletConfirm(){ - return await this.driver.findElement(By.xpath(tokenCardPopoverDeletConfirm)); - } -} - -module.exports = tokensTab; diff --git a/e2e/src/pages/monitoring/alertsPage.js b/e2e/src/pages/monitoring/alertsPage.js deleted file mode 100644 index 793a81acfb..0000000000 --- a/e2e/src/pages/monitoring/alertsPage.js +++ /dev/null @@ -1,266 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const pageTitle = '[data-testid=\'page-title\']'; -const createCheckButton = '[data-testid=create-check]'; -const createEndpointButton = '[data-testid=create-endpoint]'; -const createRuleButton = '[data-testid=create-rule]'; -const checksFilterInput = '[data-testid=\'filter--input checks\']'; -const checksQuestionMark = '[data-testid=\'Checks--question-mark\']'; -const checksTooltipContents = '[data-testid=\'Checks--question-mark--tooltip--contents\']'; -const alertingTab = '[data-testid=alerting-tab--%TABNAME%]'; -const createCheckDropdown = '[data-testid=\'checks--column\'] [data-testid=\'dropdown-menu--contents\']'; -const createCheckDropdownItem = '[data-testid=\'dropdown-menu--contents\'] [data-testid=create-%ITEM%-check]'; -const endpointsFilterInput = '[data-testid=\'filter--input endpoints\']'; -const endpointsQuestionMark = '[data-testid=\'Notification Endpoints--question-mark\']'; -const endpointsTooltipContents = '[data-testid=\'Notification Endpoints--question-mark--tooltip--contents\']'; -const rulesFilterInput = '[data-testid=\'filter--input rules\']'; -const rulesQuestionMark = '[data-testid=\'Notification Rules--question-mark\']'; -const rulesTooltipContents = '[data-testid=\'Notification Rules--question-mark--tooltip--contents\']'; -const firstTimeThresholdCheckCreateButton = '[data-testid=\'checks--column\'] [data-testid=panel--body] [data-testid=button][title=\'Threshold Check\']'; -const firstTimeDeadmanCheckCreateButton = '[data-testid=\'checks--column\'] [data-testid=panel--body] [data-testid=button][title=\'Deadman Check\']'; -const emptyStateColumnText = '[data-testid=\'%COL%--column\'] [data-testid=\'empty-state--text\']'; - -//Resource card -const checkCardName = '//*[@data-testid=\'check-card--name\'][./*[text()=\'%NAME%\']]'; -const checkCardNameEditButton = '//*[./*/*[text()=\'%NAME%\']]//*[@data-testid=\'check-card--name-button\']'; -const checkCardNameInput = '[data-testid=check-card--input]'; -const checkCardDescription = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'resource-list--editable-description\']'; -const checkCardDescriptionEditButton = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'resource-list--editable-description\']//*[@data-testid=\'icon\']'; -const checkCardDescriptionInput = '[data-testid=check-card] [data-testid=input-field]'; -const checkCardAddLabelButton = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'inline-labels--add\']'; -const checkCardLabelEmpty = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'inline-labels--empty\']'; -const checkCardLabelPill = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'label--pill %LABEL%\']'; -const checkCardLabelRemove = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'label--pill--delete %LABEL%\']'; -const checkCardCloneButton = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-menu\'][./*[contains(@class,\'duplicate\')]]'; -const checkCardCloneConfirm = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-menu-item\'][text()=\'Clone\']'; -const checkCardOpenHistory = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-history-menu\'][./*[contains(@class,\'eye-open\')]]'; -const checkCardOpenHistoryConfirm = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-history-task\']'; -const checkCardDeleteButton = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-delete-menu\']'; -const checkCardDeleteConfirm = '//*[@data-testid=\'check-card\'][.//*[text()=\'%NAME%\']]//*[@data-testid=\'context-delete-task\']' - - -//Create Endpoint Popup -const epPopupEndpointDropdownButton = '[data-testid=endpoint--dropdown--button]'; -const epPopupEndpointNameInput = '[data-testid=endpoint-name--input]'; -const epPopupEndpointDescriptionText = '[data-testid=endpoint-description--textarea]'; -const epPopupCancelButton = '[data-testid=endpoint-cancel--button]'; -const epPopupSaveButton = '[data-testid=endpoint-save--button]'; - -//Query Builder -const qbSelectorListItem = '[data-testid=\'selector-list %ITEM%\']'; - - -const urlCtx = 'alerting'; - -class alertsPage extends influxPage { - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: pageTitle}, - {type: 'css', selector: createCheckButton}, - {type: 'css', selector: createEndpointButton}, - {type: 'css', selector: createRuleButton}, - {type: 'css', selector: checksFilterInput}, - {type: 'css', selector: endpointsFilterInput}, - {type: 'css', selector: rulesFilterInput}, - ], urlCtx); - } - - - async getPageTitle(){ - return await this.driver.findElement(By.css(pageTitle)); - } - - async getAlertingTab(tabName){ - return await this.driver.findElement(By.css(alertingTab.replace('%TABNAME%', tabName))); - } - - async getCreateCheckButton(){ - return await this.driver.findElement(By.css(createCheckButton)); - } - - async getCreateEndpointButton(){ - return await this.driver.findElement(By.css(createEndpointButton)); - } - - async getCreateRuleButton(){ - return await this.driver.findElement(By.css(createRuleButton)); - } - - async getChecksQuestionMark(){ - return await this.driver.findElement(By.css(checksQuestionMark)); - } - - async getChecksFilterInput(){ - return await this.driver.findElement(By.css(checksFilterInput)); - } - - async getChecksTooltipContents(){ - return await this.driver.findElement(By.css(checksTooltipContents)); - } - - static getChecksTooltipContentsSelector(){ - return { type: 'css', selector: checksTooltipContents }; - } - - async getEndpointsQuestionMark(){ - return await this.driver.findElement(By.css(endpointsQuestionMark)); - } - - async getEndpointsFilterInput(){ - return await this.driver.findElement(By.css(endpointsFilterInput)); - } - - async getEndpointsTooltipContents(){ - return await this.driver.findElement(By.css(endpointsTooltipContents)); - } - - static getEndpointsTooltipContentsSelector(){ - return { type: 'css', selector: endpointsTooltipContents }; - } - - async getRulesFilterInput(){ - return await this.driver.findElement(By.css(rulesFilterInput)); - } - - async getRulesQuestionMark(){ - return await this.driver.findElement(By.css(rulesQuestionMark)); - } - - async getRulesTooltipContents(){ - return await this.driver.findElement(By.css(rulesTooltipContents)); - } - - static getRulesTooltipContentsSelector(){ - return { type: 'css', selector: rulesTooltipContents }; - } - - async getFirstTimeThresholdCheckCreateButton(){ - return await this.driver.findElement(By.css(firstTimeThresholdCheckCreateButton)); - } - - async getFirstTimeDeadmanCheckCreateButton(){ - return await this.driver.findElement(By.css(firstTimeDeadmanCheckCreateButton)); - } - - async getCreateCheckDropdownItem(item){ - return await this.driver.findElement(By.css(createCheckDropdownItem.replace('%ITEM%', item.toLowerCase()))); - } - - static getCreateCheckDropdownSelector(){ - return { type: 'css', selector: createCheckDropdown } - } - - async getEpPopupEndpointDropdownButton(){ - return await this.driver.findElement(By.css(epPopupEndpointDropdownButton)); - } - - async getEpPopupEndpointNameInput(){ - return await this.driver.findElement(By.css(epPopupEndpointNameInput)); - } - - async getEpPopupEndpointDescriptionText(){ - return await this.driver.findElement(By.css(epPopupEndpointDescriptionText)); - } - - async getEpPopupCancelButton(){ - return await this.driver.findElement(By.css(epPopupCancelButton)); - } - - async getEpPopupSaveButton(){ - return await this.driver.findElement(By.css(epPopupSaveButton)); - } - - async getQbSelectorListItem(item){ - return await this.driver.findElement(By.css(qbSelectorListItem.replace('%ITEM%', item))) - } - - async getCheckCardName(name){ - return await this.driver.findElement(By.xpath(checkCardName.replace('%NAME%', name))); - } - - static getCheckCardNameSelector(name){ - return {type: 'xpath', selector: checkCardName.replace('%NAME%', name)} - } - - async getCheckCardNameEditButton(name){ - return await this.driver.findElement(By.xpath(checkCardNameEditButton.replace('%NAME%', name))); - } - - async getCheckCardNameInput(){ - return await this.driver.findElement(By.css(checkCardNameInput)); - } - - async getCheckCardDescription(name){ - return await this.driver.findElement(By.xpath(checkCardDescription.replace('%NAME%', name))); - } - - async getCheckCardDescriptionEditButton(name){ - return await this.driver.findElement(By.xpath(checkCardDescriptionEditButton.replace('%NAME%', name))); - } - - async getCheckCardDescriptionInput(){ - return await this.driver.findElement(By.css(checkCardDescriptionInput)); - } - - async getCheckCardAddLabelButton(name){ - return await this.driver.findElement(By.xpath(checkCardAddLabelButton.replace('%NAME%', name))); - } - - async getCheckCardLabelEmpty(name){ - return await this.driver.findElement(By.xpath(checkCardLabelEmpty.replace('%NAME%', name))); - } - - async getCheckCardLabelPill(name, label){ - return await this.driver.findElement(By.xpath(checkCardLabelPill - .replace('%NAME%', name) - .replace('%LABEL%', label))); - } - - static getCheckCardLabelPillSelector(name, label){ - return { type: 'xpath', selector: checkCardLabelPill - .replace('%NAME%', name) - .replace('%LABEL%', label)} - } - - async getCheckCardLabelRemove(name, label){ - return await this.driver.findElement(By.xpath(checkCardLabelRemove - .replace('%NAME%', name) - .replace('%LABEL%', label))); - } - - async getCheckCardCloneButton(name){ - return await this.driver.findElement(By.xpath(checkCardCloneButton.replace('%NAME%', name))) - } - - async getCheckCardCloneConfirm(name){ - return await this.driver.findElement(By.xpath(checkCardCloneConfirm.replace('%NAME%', name))) - } - - async getEmptyStateColumnText(col){ - return await this.driver.findElement(By.css(emptyStateColumnText.replace('%COL%', col))); - } - - async getCheckCardOpenHistory(name){ - return await this.driver.findElement(By.xpath(checkCardOpenHistory.replace('%NAME%', name))) - } - - async getCheckCardOpenHistoryConfirm(name){ - return await this.driver.findElement(By.xpath(checkCardOpenHistoryConfirm.replace('%NAME%', name))); - } - - async getCheckCardDeleteButton(name){ - return await this.driver.findElement(By.xpath(checkCardDeleteButton.replace('%NAME%', name))); - } - - async getCheckCardDeleteConfirm(name){ - return await this.driver.findElement(By.xpath(checkCardDeleteConfirm.replace('%NAME%', name))); - } - -} - -module.exports = alertsPage; diff --git a/e2e/src/pages/monitoring/checkEditPage.js b/e2e/src/pages/monitoring/checkEditPage.js deleted file mode 100644 index c1e0ba1488..0000000000 --- a/e2e/src/pages/monitoring/checkEditPage.js +++ /dev/null @@ -1,198 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const thresholds = ["CRIT", "WARN", "INFO", "OK"]; - -const overlay = '[data-testid=overlay]'; -const dismissButton = '[data-testid=page-control-bar] [data-testid=square-button]'; -const saveCellButton = '[data-testid=overlay] [data-testid=save-cell--button]'; -const pageCheckEditTitle = '[data-testid=overlay] [data-testid=page-header] [data-testid=page-title]'; -const pageCheckEditTitleInput = '[data-testid=\'renamable-page-title--input\' ]'; -const queriesToggle = '[data-testid=overlay] [data-testid=select-group--option][title=queries]'; -const configureCheckToggle = '[data-testid=overlay] [data-testid=\'checkeo--header alerting-tab\']'; -const defineQueryToggle = '[data-testid=select-group--option]'; -const checklistPopover = '[data-testid=popover--contents] [class=query-checklist--popover]'; -const checklistPopoverItemByText = '//*[@data-testid=\'popover--contents\']//*[text()=\'%TEXT%\']'; - -//Preview area -const previewThresholdHandleByLevel = '[class*=\'threshold-marker--handle threshold-marker--%LEVEL%\']'; - - -// TODO timemachine controls -- see dashboards - try and reuse - -// Configure Check Controls - -// Properties -const confChkIntervalInput = '[data-testid=schedule-check]'; -const confChkOffset = '[data-testid=offset-options]'; -const confChkAddTagButton = '//*[./*/*[text() = \'Tags\']]//*[@data-testid=\'dashed-button\']'; -// Status Message Template -const confChkMessageTextArea = '[data-testid=status-message-textarea]'; - -const confTagRuleKeyInputOfTag = '[data-testid=tag-rule]:nth-of-type(%INDEX%) [data-testid=\'tag-rule-key--input\'][name=key]'; -const confTagRuleValueInputOfTag = '[data-testid=tag-rule]:nth-of-type(%INDEX%) [data-testid=\'tag-rule-key--input\'][name=value]'; -const confTagRuleDimissOfTag = '[data-testid=tag-rule]:nth-of-type(%INDEX%) [data-testid=dismiss-button]'; - - -// Thresholds -const confChkAddThresholdButton = '[data-testid=add-threshold-condition-%STATUS%]'; -const confNthThresholdDefDropdownButton = '[data-testid=overlay] [data-testid=panel]:nth-of-type(%INDEX%) [data-testid=select-option-dropdown]'; -const confNthThresholdDefDropdownItem = '[data-testid=overlay] [data-testid=panel]:nth-of-type(%INDEX%) [data-testid=select-option-dropdown] [data-testid=dropdown-item][title=\'%ITEM%\']'; -const confNthThresholdDefInput = '[data-testid=overlay] [data-testid=panel]:nth-of-type(%INDEX%) [data-testid=input-field]'; -const confNthThreshold2ndInput = '[data-testid=overlay] [data-testid=panel]:nth-of-type(%INDEX%) [data-testid^=\'component-spacer--flex-child\']:nth-of-type(3) [data-testid=input-field]'; -//Deadman -const confDeadmanForInput = '//*[@data-testid=\'component-spacer\']/*[@data-testid=\'component-spacer\'][.//*[text()=\'for\']]//*[@data-testid=\'duration-input\']'; -const confDeadmanForInputDropdownItem = '//*[@data-testid=\'component-spacer\']/*[@data-testid=\'component-spacer\'][.//*[text()=\'for\']]//*[@data-testid=\'dropdown-item\'][.//*[text()=\'%ITEM%\']]'; -const confDeadmanStopInput = '//*[@data-testid=\'component-spacer\']/*[@data-testid=\'component-spacer\'][.//*[text()=\'And stop checking after\']]//*[@data-testid=\'duration-input\']'; -const confDeadmanStopInputDropdownItem = '//*[@data-testid=\'component-spacer\']/*[@data-testid=\'component-spacer\'][.//*[text()=\'And stop checking after\']]//*[@data-testid=\'dropdown-item\'][.//*[text()=\'%ITEM%\']]'; -const confDeadmanCheckLevelsDropdown = '//*[@data-testid=\'component-spacer\']/*[@data-testid=\'component-spacer\']//*[@data-testid=\'check-levels--dropdown--button\']'; -const confDeadmanCheckLevelsDropodownItem = '[data-testid=\'check-levels--dropdown-item %LEVEL%\']'; -const confDeadmanCheckLevelsDropdownSelected = '[data-testid^=check-levels--dropdown--button] [class*=\'selected\'] [class*=\'dropdown--name\']'; - - -const urlCtx = 'checks'; - -class checkEditPage extends influxPage { - - constructor(driver) { - super(driver); - } - - async isLoaded(){ - await super.isLoaded([ - {type: 'css', selector: dismissButton}, - {type: 'css', selector: pageCheckEditTitle}, - {type: 'css', selector: queriesToggle}, - {type: 'css', selector: configureCheckToggle} - ], urlCtx); - } - - static getOverlaySelector(){ - return { type: 'css', selector: overlay}; - } - - async getSaveCellButton(){ - return await this.driver.findElement(By.css(saveCellButton)); - } - - async getDismissButton(){ - return await this.driver.findElement(By.css(dismissButton)); - } - - async getPageCheckEditTitle(){ - return await this.driver.findElement(By.css(pageCheckEditTitle)); - } - - async getQueriesToggle(){ - return await this.driver.findElement(By.css(queriesToggle)); - } - - async getConfigureCheckToggle(){ - return await this.driver.findElement(By.css(configureCheckToggle)) - } - - async getDefineQueryToggle(){ - return await this.driver.findElement(By.css(defineQueryToggle)); - } - - async getChecklistPopover(){ - return await this.driver.findElement(By.css(checklistPopover)); - } - - async getPageCheckEditTitleInput(){ - return await this.driver.findElement(By.css(pageCheckEditTitleInput)); - } - - async getConfChkIntervalInput(){ - return await this.driver.findElement(By.css(confChkIntervalInput)); - } - - async getConfChkOffset(){ - return await this.driver.findElement(By.css(confChkOffset)); - } - - async getConfChkAddTagButton(){ - return await this.driver.findElement(By.xpath(confChkAddTagButton)); - } - - async getConfChkMessageTextArea(){ - return await this.driver.findElement(By.css(confChkMessageTextArea)); - } - - async getConfChkAddThresholdButton(status){ - return await this.driver.findElement(By.css(confChkAddThresholdButton.replace('%STATUS%', status))); - } - - async getConfNthThresholdDefDropdownButton(index){ - return await this.driver.findElement(By.css(confNthThresholdDefDropdownButton - .replace('%INDEX%', await this.getThresholdIndex(index)))); - } - - async getConfNthThresholdDefDropdownItem(index, item){ - return await this.driver.findElement(By.css(confNthThresholdDefDropdownItem - .replace('%INDEX%',await this.getThresholdIndex(index)).replace('%ITEM%', item.toLowerCase()))); - } - - async getConfNthThresholdDefInput(index){ - return await this.driver.findElement(By.css(confNthThresholdDefInput.replace('%INDEX%', await this.getThresholdIndex(index)))); - } - - async getConfNthThreshold2ndInput(index){ - return await this.driver.findElement(By.css(confNthThreshold2ndInput.replace('%INDEX%', await this.getThresholdIndex(index)))); - } - - async getThresholdIndex(val){ - return await thresholds.indexOf(val.toUpperCase().trim()) + 1; - } - - async getChecklistPopoverItemByText(text){ - return await this.driver.findElement(By.xpath(checklistPopoverItemByText.replace('%TEXT%', text.trim()))); - } - - async getConfDeadmanForInput(){ - return await this.driver.findElement(By.xpath(confDeadmanForInput)); - } - - async getConfDeadmanForInputDropdownItem(item){ - return await this.driver.findElement(By.xpath(confDeadmanForInputDropdownItem.replace('%ITEM%', item))); - } - - async getConfDeadmanStopInput(){ - return await this.driver.findElement(By.xpath(confDeadmanStopInput)); - } - - async getConfDeadmanStopInputDropdownItem(item){ - return await this.driver.findElement(By.xpath(confDeadmanStopInputDropdownItem.replace('%ITEM%', item))); - } - - async getConfDeadmanCheckLevelsDropdown(){ - return await this.driver.findElement(By.xpath(confDeadmanCheckLevelsDropdown)); - } - - async getConfDeadmanCheckLevelsDropodownItem(level){ - return await this.driver.findElement(By.css(confDeadmanCheckLevelsDropodownItem.replace('%LEVEL%', level))); - } - - async getConfDeadmanCheckLevelsDropdownSelected(){ - return await this.driver.findElement(By.css(confDeadmanCheckLevelsDropdownSelected)); - } - - async getPreviewThresholdHandleByLevel(level){ - return await this.driver.findElement(By.css(previewThresholdHandleByLevel.replace('%LEVEL%', level.toLowerCase()))); - } - - async getConfTagRuleKeyInputOfTag(index){ - return await this.driver.findElement(By.css(confTagRuleKeyInputOfTag.replace('%INDEX%', parseInt(index) + 2))); - } - - async getConfTagRuleValueInputOfTag(index){ - return await this.driver.findElement(By.css(confTagRuleValueInputOfTag.replace('%INDEX%', parseInt(index) + 2))); - } - - async getConfTagRuleDimissOfTag(index){ - return await this.driver.findElement(By.css(confTagRuleDimissOfTag.replace('%INDEX%', parseInt(index) + 2))); - } - -} - -module.exports = checkEditPage; diff --git a/e2e/src/pages/monitoring/checkStatusHistoryPage.js b/e2e/src/pages/monitoring/checkStatusHistoryPage.js deleted file mode 100644 index bd3c73b95b..0000000000 --- a/e2e/src/pages/monitoring/checkStatusHistoryPage.js +++ /dev/null @@ -1,124 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const alertHistoryTitle = '[data-testid=alert-history-title]'; -const filterInput = '//*[./*[@data-testid=\'check-status-input--default\']]//*[@data-testid=\'check-status-input\']'; -const eventRows = '.event-row'; -const eventRowCheckNameField = '//*[./*[@class=\'event-row\']][%INDEX%]//a'; -const eventRowsAtLevel = '//*[./*[@class=\'event-row\']]//*[contains(@class,\'level-table-field--%LEVEL%\')]'; -const eventMarkersDiv = '[data-testid=event-markers]'; -const eventFilterExamplesDropdown = '[data-testid=check-status-dropdown--contents]'; -const eventMarkerByIndex = '[data-testid=event-markers] > div:nth-of-type(%INDEX%)'; -const eventMarkers = '[data-testid=event-markers] > *'; -const eventMarkersByType = '[data-testid=event-markers] > [class*=\'event-marker--line__%TYPE%\''; -const eventMarkerToggleByType = '[data-testid=event-marker-vis-toggle-%TYPE%] > *'; - -const canvasGraphAxes = 'canvas.giraffe-axes'; -const canvasGraphContent = 'canvas.giraffe-layer-line'; -const graphToolTip = '[data-testid=giraffe-tooltip]'; -const graphToolTipColumnValue = '//*[@data-testid=\'giraffe-tooltip-table\']/*[.//*[text()=\'%COLUMN%\']]/*[2]'; - -const eventMarkerTooltip = '[data-testid=app-wrapper]'; -const eventMarkerColumnValue = '//*[@data-testid=\'app-wrapper\']//*[./*[text()=\'%COLUMN%\']]/*[2]'; - - -const eventTable = '.event-table'; - -const urlCtx = 'checks'; - -class checkStatusHistoryPage extends influxPage { - - constructor(driver) { - super(driver); - } - - async isLoaded() { - await super.isLoaded([{type: 'css', selector: alertHistoryTitle }, - {type: 'xpath', selector: filterInput }, - {type: 'css', selector: canvasGraphAxes }, - {type: 'css', selector: canvasGraphContent }, - {type: 'css', selector: eventTable} - ], urlCtx); - } - - - async getAlertHistoryTitle(){ - return await this.driver.findElement(By.css(alertHistoryTitle)); - } - - async getFilterInput(){ - return await this.driver.findElement(By.xpath(filterInput)); - } - - async getEventRows(){ - return await this.driver.findElements(By.css(eventRows)); - } - - async getEventRowCheckNameField(index){ - return await this.driver.findElement(By.xpath(eventRowCheckNameField.replace('%INDEX%', index))); - } - - async getCanvasGraphAxes(){ - return await this.driver.findElement(By.css(canvasGraphAxes)); - } - - async getCanvasGraphContent(){ - return await this.driver.findElement(By.css(canvasGraphContent)); - } - - async getEventTable(){ - return await this.driver.findElement(By.css(eventTable)); - } - - async getEventRowsAtLevel(level){ - return await this.driver.findElements(By.xpath(eventRowsAtLevel.replace('%LEVEL%', level))) - } - - async getEventMarkersDiv(){ - return await this.driver.findElement(By.css(eventMarkersDiv)); - } - - async getEventFilterExamplesDropdown(){ - return await this.driver.findElement(By.css(eventFilterExamplesDropdown)); - } - - static getEventFilterExamplesDropdownSelector(){ - return { type: 'css', selector: eventFilterExamplesDropdown}; - } - - async getEventMarkerByIndex(index){ - return await this.driver.findElement(By.css(eventMarkerByIndex.replace('%INDEX%', index))); - } - - async getEventMarkers(){ - return await this.driver.findElements(By.css(eventMarkers)); - } - - async getEventMarkersByType(){ - return await this.driver.findElement(By.css(eventMarkersByType.replace('%TYPE%', type.toLowerCase()))); - } - - async getEventMarkerToggleByType(type){ - return await this.driver.findElement(By.css(eventMarkerToggleByType.replace('%TYPE%', type.toLowerCase()))); - } - - async getEventMarkerTooltip(){ - return await this.driver.findElement(By.css(eventMarkerTooltip)); - } - - async getGraphToolTip(){ - return await this.driver.findElement(By.css(graphToolTip)); - } - - async graphToolTipColumnValue(column){ - return await this.driver.findElement(By.xpath(graphToolTipColumnValue.replace('%COLUMN%', column))); - } - - async eventMarkerColumnValue(column){ - return await this.driver.findElement(By.xpath(eventMarkerColumnValue.replace('%COLUMN%', column))); - } - -} - -module.exports = checkStatusHistoryPage; - diff --git a/e2e/src/pages/onboarding/initialSetupPage.js b/e2e/src/pages/onboarding/initialSetupPage.js deleted file mode 100644 index b600d19cef..0000000000 --- a/e2e/src/pages/onboarding/initialSetupPage.js +++ /dev/null @@ -1,58 +0,0 @@ -const basePage = require(__srcdir + '/pages/basePage.js'); -const { By, until} = require('selenium-webdriver'); - -const headerMain = '[data-testid=admin-step--head-main]'; -const navCrumbToken = 'data-testid=nav-step--'; -const inputFieldToken = 'data-testid=input-field--'; -const nextButton = '[data-testid=next]'; -const formErrorMessage = '[data-testid=form--element-error]'; - - -class initialSetupPage extends basePage { - - constructor(driver){ - super(driver); - } - - async getHeaderMain(){ - return await this.driver.findElement(By.css(headerMain)); - } - - - async getCrumbStep(step){ - return await this.driver.findElement(By.css(`[${navCrumbToken}${step}]`)); - } - - async getInputField(name){ - return await this.driver.findElement(By.css(`[${inputFieldToken}${name}]`)); - } - - async getNextButton(){ - return this.driver.wait(until.elementLocated(By.css(nextButton))); - //return await this.driver.findElement(By.css(nextButton)) - } - - async getFormErrorMessage(){ - return this.driver.wait(until.elementLocated(By.css(formErrorMessage))); - } - - async isFormErrorDisplayed(){ - try { - await this.driver.findElement(By.css(formErrorMessage)).isDisplayed(); - return true; - }catch(err){ - if(err.name === 'NoSuchElementError'){ - return false; - }else{ - throw err; - } - } - } - - async isNextButtonEnabled(){ - return await this.driver.findElement(By.css(nextButton)).isEnabled(); - } - -} - -module.exports = initialSetupPage; diff --git a/e2e/src/pages/onboarding/readyPage.js b/e2e/src/pages/onboarding/readyPage.js deleted file mode 100644 index a3badf155e..0000000000 --- a/e2e/src/pages/onboarding/readyPage.js +++ /dev/null @@ -1,39 +0,0 @@ -const basePage = require(__srcdir + '/pages/basePage.js'); -const { By, until} = require('selenium-webdriver'); - -const subtitle = 'h5.wizard-step--sub-title:first-of-type'; -const qStartButton = '[data-testid=button--quick-start]'; -const advancedButton = '[data-testid=button--advanced]'; -const laterButton = '[data-testid=button--conf-later]'; -const urlCtx = '/onboarding/2'; - -class readyPage extends basePage { - - constructor(driver){ - super(driver); - } - - async getSubtitle(){ - return this.driver.wait(until.elementLocated(By.css(subtitle))); - //return await this.driver.findElement(By.css(subtitle)) - } - - async getQuickStartButton(){ - return await this.driver.findElement(By.css(qStartButton)); - } - - async getAdvancedButton(){ - return await this.driver.findElement(By.css(advancedButton)); - } - - - async isLoaded(){ - await super.isLoaded([{type:'css', selector:subtitle}, - {type:'css', selector:qStartButton}, - {type:'css', selector:advancedButton}, - {type:'css', selector:laterButton}], urlCtx); - } - -} - -module.exports = readyPage; diff --git a/e2e/src/pages/onboarding/splashPage.js b/e2e/src/pages/onboarding/splashPage.js deleted file mode 100644 index 1ccf9ee811..0000000000 --- a/e2e/src/pages/onboarding/splashPage.js +++ /dev/null @@ -1,30 +0,0 @@ -const basePage = require(__srcdir + '/pages/basePage.js'); -const { By } = require('selenium-webdriver'); - -const headMain = '[data-testid=init-step--head-main]'; -const creditsLink = '[data-testid=credits] a'; -const startButton = '[data-testid=onboarding-get-started]'; - -class splashPage extends basePage { - - constructor(driver){ - super(driver); - } - - async getHeadMain(){ - //promises 201 - passing promises between methods - //N.B. returns a promise wrapping the element - return await this.driver.findElement(By.css(headMain)); - } - - async getCreditsLink(){ - return await this.driver.findElement(By.css(creditsLink)); - } - - async getStartButton(){ - return await this.driver.findElement(By.css(startButton)); - } - -} - -module.exports = splashPage; diff --git a/e2e/src/pages/organization/organizationPage.js b/e2e/src/pages/organization/organizationPage.js deleted file mode 100644 index 57ed2d5514..0000000000 --- a/e2e/src/pages/organization/organizationPage.js +++ /dev/null @@ -1,35 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const tabsCss = '[data-testid=tabs]'; -const tabsXpath = '//*[@data-testid=\'tabs\']'; - -const urlCtx = 'members'; - -class organizationPage extends influxPage { - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: tabsCss}], urlCtx); - } - - async isTabLoaded(tabUrlPart, selectors = undefined){ - if(selectors) { - await super.isLoaded(selectors.concat([{type: 'css', selector: tabsCss}]), tabUrlPart); - }else{ - await super.isLoaded([{type: 'css', selector: tabsCss}], tabUrlPart); - } - } - - async getTabByName(name){ - return await this.driver.findElement(By.xpath(`${tabsXpath}//a[@data-testid='tabs--tab'][.//*[text()='${name}']]`)); - } - - //`//div[@class='site-bottom-wrapper'][descendant::a[contains(.,'${ siteName }')]]//div[contains(@class, 'manage-settings')]` - -} - -module.exports = organizationPage; \ No newline at end of file diff --git a/e2e/src/pages/settings/labelsTab.js b/e2e/src/pages/settings/labelsTab.js deleted file mode 100644 index 70f2144bf5..0000000000 --- a/e2e/src/pages/settings/labelsTab.js +++ /dev/null @@ -1,140 +0,0 @@ -const { By } = require('selenium-webdriver'); - -const settingsPage = require(__srcdir + '/pages/settings/settingsPage.js'); -const basePage = require(__srcdir + '/pages/basePage.js'); - -const labelsFilter = '[data-testid=search-widget]'; -const createLabelHeader = '[data-testid=button-create]'; -const labelNameSort = '[data-testid=sorter--name]'; -const labelDescSort = '[data-testid=sorter--desc]'; -const createLabelEmpty = '[data-testid=button-create-initial]'; -const labelCard = '//*[@data-testid=\'label-card\'][.//span[text()=\'%NAME%\']]'; -const labelCardPills = '[data-testid^=label--pill]'; -const labelCardPill = '//*[@data-testid=\'label-card\']//div[./span[@data-testid=\'label--pill %NAME%\']]'; -const labelCardDescr = '//*[@data-testid=\'label-card\'][.//span[text()=\'%NAME%\']]//*[@data-testid=\'label-card--description\']'; -const labelCardDelete = '//*[@data-testid=\'label-card\'][.//span[text()=\'%NAME%\']]//button[@data-testid=\'context-delete-menu\']'; -const labelCardDeleteConfirm = '//*[@data-testid=\'label-card\'][.//span[text()=\'%NAME%\']]//button[@data-testid=\'context-delete-label\']'; - -const urlCtx = 'labels'; - -//Create Label Popup -const labelPopupNameInput = '[data-testid=create-label-form--name]'; -const labelPopupDescrInput = '[data-testid=create-label-form--description]'; -const labelPopupColorPicker = '[data-testid=color-picker]'; -const labelPopupColorInput = '[data-testid=color-picker--input]'; -const labelPopupCreateBtn = '[data-testid=create-label-form--submit]'; -const labelPopupCancelBtn = '[data-testid=create-label-form--cancel]'; -const labelPopupPreview = '[data-testid=overlay--body] [data-testid=form--box] div'; -const labelPopupPreviewPill = '[data-testid=overlay--body] [data-testid^=label--pill]'; -const labelPopupRandomColor = '[data-testid=color-picker--randomize]'; -const labelPopupColorSwatch = '[data-testid=color-picker--swatch][title=\'%NAME%\']'; - -class labelsTab extends settingsPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: labelsFilter}, - {type: 'css', selector: createLabelHeader}, - basePage.getSortTypeButtonSelector() - //{type: 'css', selector: labelNameSort}, - //{type: 'css', selector: labelDescSort}, - ] - ); - } - - async getLabelNameSort(){ - return await this.driver.findElement(By.css(labelNameSort)); - } - - async getLabelDescSort(){ - return await this.driver.findElement(By.css(labelDescSort)); - } - - async getLabelsFilter(){ - return await this.driver.findElement(By.css(labelsFilter)); - } - - async getCreateLabelHeader(){ - return await this.driver.findElement(By.css(createLabelHeader)); - } - - async getCreateLabelEmpty(){ - return await this.driver.findElement(By.css(createLabelEmpty)); - } - - async getLabelPopupNameInput(){ - return await this.driver.findElement(By.css(labelPopupNameInput)); - } - - async getLabelPopupDescrInput(){ - return await this.driver.findElement(By.css(labelPopupDescrInput)); - } - - async getLabelPopupColorPicker(){ - return await this.driver.findElement(By.css(labelPopupColorPicker)); - } - - async getLabelPopupColorInput(){ - return await this.driver.findElement(By.css(labelPopupColorInput)); - } - - async getLabelPopupCreateBtn(){ - return await this.driver.findElement(By.css(labelPopupCreateBtn)); - } - - async getLabelPopupCancelBtn(){ - return await this.driver.findElement(By.css(labelPopupCancelBtn)); - } - - async getLabelPopupPreview(){ - return await this.driver.findElement(By.css(labelPopupPreview)); - } - - async getLabelPopupPreviewPill(){ - return await this.driver.findElement(By.css(labelPopupPreviewPill)); - } - - async getLabelPopupRandomColor(){ - return await this.driver.findElement(By.css(labelPopupRandomColor)); - } - - async getLabelPopupColorSwatch(name){ - return await this.driver.findElement(By.css(labelPopupColorSwatch.replace('%NAME%', name))); - } - - async getLabelCard(name){ - return await this.driver.findElement(By.xpath(labelCard.replace('%NAME%', name))); - } - - static getLabelCardSelector(name){ - return { type: 'xpath', selector: labelCard.replace('%NAME%', name)}; - } - - async getLabelCardPill(name){ - return await this.driver.findElement(By.xpath(labelCardPill.replace('%NAME%', name))); - } - - async getLabelCardPills(){ - return await this.driver.findElements(By.css(labelCardPills)); - } - - async getLabelCardDescr(name){ - return await this.driver.findElement(By.xpath(labelCardDescr.replace('%NAME%', name))); - } - - async getLabelCardDelete(name){ - return await this.driver.findElement(By.xpath(labelCardDelete.replace('%NAME%', name))); - } - - async getLabelCardDeleteConfirm(name){ - return await this.driver.findElement(By.xpath(labelCardDeleteConfirm.replace('%NAME%', name))); - } - -} - -module.exports = labelsTab; diff --git a/e2e/src/pages/settings/membersTab.js b/e2e/src/pages/settings/membersTab.js deleted file mode 100644 index 46f413cc37..0000000000 --- a/e2e/src/pages/settings/membersTab.js +++ /dev/null @@ -1,25 +0,0 @@ -const settingsPage = require(__srcdir + '/pages/settings/settingsPage.js'); - -const variablesFilter = '[data-testid=search-widget]'; -//const addMemberButton = '[data-testid=flex-box] [data-testid=button]'; - -const urlCtx = 'members'; - -class membersTab extends settingsPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: variablesFilter}, - // {type: 'css', selector: addMemberButton}, - ] - ); - } - -} - -module.exports = membersTab; diff --git a/e2e/src/pages/settings/orgProfileTab.js b/e2e/src/pages/settings/orgProfileTab.js deleted file mode 100644 index ff9c17aab1..0000000000 --- a/e2e/src/pages/settings/orgProfileTab.js +++ /dev/null @@ -1,27 +0,0 @@ -const settingsPage = require(__srcdir + '/pages/settings/settingsPage.js'); - -const tabHeader = '//*[@data-testid=\'flex-box\'][.//h5]'; -const warningHeader = '//*[@data-testid=\'flex-box\']//p'; -const renameButton = '[data-testid=button][title=\'Rename\']'; - -const urlCtx = 'about'; - -class orgProfileTab extends settingsPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'xpath', selector: tabHeader}, - {type: 'xpath', selector: warningHeader}, - {type: 'css', selector: renameButton}, - ] - ); - } - -} - -module.exports = orgProfileTab; diff --git a/e2e/src/pages/settings/settingsPage.js b/e2e/src/pages/settings/settingsPage.js deleted file mode 100644 index 4b9adc1cc4..0000000000 --- a/e2e/src/pages/settings/settingsPage.js +++ /dev/null @@ -1,33 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const { By } = require('selenium-webdriver'); - -const tabsCss = '[data-testid=tabs]'; -const tabsXpath = '//*[@data-testid=\'tabs\']'; - -const urlCtx = 'settings'; - -class settingsPage extends influxPage { - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: tabsCss}], urlCtx); - } - - async isTabLoaded(tabUrlPart, selectors = undefined){ - if(selectors) { - await super.isLoaded(selectors.concat([{type: 'css', selector: tabsCss}]), tabUrlPart); - }else{ - await super.isLoaded([{type: 'css', selector: tabsCss}], tabUrlPart); - } - } - - async getTabByName(name){ - return await this.driver.findElement(By.xpath(`${tabsXpath}//div[@data-testid='${name.toLowerCase()}--tab']`)); - } - -} - -module.exports = settingsPage; diff --git a/e2e/src/pages/settings/templatesTab.js b/e2e/src/pages/settings/templatesTab.js deleted file mode 100644 index 116659221d..0000000000 --- a/e2e/src/pages/settings/templatesTab.js +++ /dev/null @@ -1,115 +0,0 @@ -const { By } = require('selenium-webdriver'); - -const settingsPage = require(__srcdir + '/pages/settings/settingsPage.js'); - -const templatesFilter = '[data-testid=search-widget]'; -const importTemplateHeaderButton = '//*[@data-testid=\'button\'][.//*[text()=\'Import Template\']]'; -const sortTypeButton = '[data-testid=resource-sorter--button]'; -const nameSort = '[data-testid=resource-list--sorter]:nth-of-type(1)'; -const templatesTypeFilterButton = '[data-testid=select-group--option][title=\'Static Templates\']'; -const userTemplatesRadioButton = '[data-testid=select-group--option][title=\'User Templates\']'; -const resourceList = '[data-testid=resource-list]'; -const templateCardNames = '[data-testid=template-card--name]'; -const importTemplateEmptyButton = '[data-testid=empty-state] [data-testid=button]'; -const templateCardByName = '//*[@data-testid=\'template-card\'][.//*[text() = \'%NAME%\']]'; -const templateCardCtxDelete = '//*[@data-testid=\'template-card\'][.//*[text() = \'%NAME%\']]//*[@data-testid=\'context-delete-menu\']'; -const templateCardDeleteConfirm = '//*[@data-testid=\'template-card\'][.//*[text() = \'%NAME%\']]//*[@data-testid=\'context-delete-task\']'; - -const urlCtx = 'templates'; - -//import template popup -const importTemplateUploadButton = '[data-testid=overlay--body] [data-testid=select-group--option][title=Upload]'; -const importTemplatePasteButton = '[data-testid=overlay--body] [data-testid=select-group--option][title=Paste]'; -const importTemplateJSONTextArea = '[data-testid=overlay--body] [data-testid=import-overlay--textarea]'; -const importTemplateDragNDrop = '[data-testid=overlay--body] input[type=file]'; -const importTemplateSubmitButton = '[data-testid=\'submit-button Template\']'; - -class templatesTab extends settingsPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: templatesFilter}, - {type: 'xpath', selector: importTemplateHeaderButton}, - {type: 'css', selector: sortTypeButton}, - {type: 'css', selector: templatesTypeFilterButton}, - {type: 'css', selector: resourceList}, - ] - ); - } - - async getTemplateCardNames(){ - return await this.driver.findElements(By.css(templateCardNames)); - } - - async getUserTemplatesRadioButton(){ - return await this.driver.findElement(By.css(userTemplatesRadioButton)); - } - - async getImportTemplateEmptyButton(){ - return await this.driver.findElement(By.css(importTemplateEmptyButton)); - } - - async getImportTemplateUploadButton(){ - return await this.driver.findElement(By.css(importTemplateUploadButton)); - } - - async getImportTemplatePasteButton(){ - return await this.driver.findElement(By.css(importTemplatePasteButton)); - } - - async getImportTemplateHeaderButton(){ - return await this.driver.findElement(By.xpath(importTemplateHeaderButton)); - } - - async getImportTemplateJSONTextArea(){ - return await this.driver.findElement(By.css(importTemplateJSONTextArea)); - } - - static getImportTemplateJSONTextAreaSelector(){ - return { type: 'css', selector: importTemplateJSONTextArea}; - } - - async getImportTemplateDragNDrop(){ - return await this.driver.findElement(By.css(importTemplateDragNDrop)); - } - - async getImportTemplateSubmitButton(){ - return await this.driver.findElement(By.css(importTemplateSubmitButton)); - } - - async getTemplateCardByName(name){ - return await this.driver.findElement(By.xpath(templateCardByName.replace('%NAME%', name))); - } - - static getTemplateCardSelectorByName(name){ - return { type: 'xpath', selector: templateCardByName.replace('%NAME%', name) }; - } - - async getTemplatesFilter(){ - return await this.driver.findElement(By.css(templatesFilter)); - } - - async getSortTypeButton(){ - return await this.driver.findElement(By.css(sortTypeButton)); - } - - async getNameSort(){ - return await this.driver.findElement(By.css(nameSort)); - } - - async getTemplateCardCtxDelete(name){ - return await this.driver.findElement(By.xpath(templateCardCtxDelete.replace('%NAME%', name))); - } - - async getTemplateCardDeleteConfirm(name){ - return await this.driver.findElement(By.xpath(templateCardDeleteConfirm.replace('%NAME%', name))); - } - -} - -module.exports = templatesTab; diff --git a/e2e/src/pages/settings/variablesTab.js b/e2e/src/pages/settings/variablesTab.js deleted file mode 100644 index d4c5af3adc..0000000000 --- a/e2e/src/pages/settings/variablesTab.js +++ /dev/null @@ -1,250 +0,0 @@ -const { By } = require('selenium-webdriver'); -const settingsPage = require(__srcdir + '/pages/settings/settingsPage.js'); -const basePage = require(__srcdir + '/pages/basePage.js'); - -const variablesFilter = '[data-testid=search-widget]'; -const createVariableHeader = '[data-testid=\'tabbed-page--header\'] [data-testid=add-resource-dropdown--button]'; -const nameSort = '[data-testid=resource-list--sorter]:nth-of-type(1)'; -const typeSort = '[data-testid=resource-list--sorter]:nth-of-type(2)'; -const createVariableEmpty = '[data-testid=resource-list--body] [data-testid=add-resource-dropdown--button]'; -const createVariableItem = '[data-testid=add-resource-dropdown--%ITEM%]'; -const variableCardNamed = '//*[@data-testid=\'resource-card variable\'][.//*[text()=\'%NAME%\']]'; -const variableCardNames = '[data-testid^=\'variable-card--name\'] span'; -const variableCardName = '//*[@data-testid=\'variable-card--name %NAME%\']//span[text()=\'%NAME%\']'; -const variableCardContextMenu = '//*[@data-testid=\'resource-card variable\'][.//span[text()=\'%NAME%\']]//*[@data-testid=\'context-menu\']'; -const variableCardContextMenuItem = '//*[@data-testid=\'resource-card variable\'][.//span[text()=\'%NAME%\']]//*[button[@data-testid=\'context-menu\']]//button[text()=\'%ITEM%\']'; -const variableCardContextDelete = '//*[@data-testid=\'resource-card variable\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'context-delete-menu\']'; -const variableCardContextDeleteConfirm = '//*[@data-testid=\'resource-card variable\'][.//span[text() = \'%NAME%\']]//*[@data-testid=\'context-delete-variable\']'; - -const urlCtx = 'variables'; - -// import variable popup -const uploadRadioButton = '[data-testid=overlay--body] [data-testid=select-group--option][title=Upload]'; -const pasteRadioButton = '[data-testid=overlay--body] [data-testid=select-group--option][title=Paste]'; -const dragNDropFile = 'input[type=file]'; //N.B. has display:none -const importButton = '[data-testid=overlay--footer] [data-testid=\'submit-button Variable\']'; -const pasteJSONTextarea = '[data-testid=overlay--body] [data-testid=import-overlay--textarea]'; -const importVariableDragNDropHeader = '.drag-and-drop--header'; - -// create variable popup -const createVarPopupCreateButton = '[data-testid=overlay--container] button[title=\'Create Variable\']'; -const createVariableNameInput = '[data-testid=overlay--body] [data-testid=input-field]'; -const createVariableTypeDropdown = '[data-testid=\'variable-type-dropdown--button\']'; -const createVariableQueryCodeMirror = '.CodeMirror'; -const createVariableQueryMonacoEdit = '.monaco-editor'; -const createVariableTextArea = '[data-testid=overlay--body] [data-testid=textarea]'; -const createVariableTypeDropdownItem = '[data-testid=\'variable-type-dropdown-%ITEM%\']'; -const createVariableDefaultValDropdown = '//*[@data-testid=\'form--element\'][.//*[text() = \'Select A Default\']]//*[contains(@data-testid,\'dropdown--button\')]'; -const createVariableInfoPara = '//*[@data-testid=\'grid--column\'][p[contains(text(), \'ontains\')]]'; -const createVariableDefaultValDropdownItem = '[data-testid=dropdown-item][id=\'%ITEM%\']'; -const createVariableDefaultValCSVDropdownItem = '//*[@data-testid=\'dropdown-item\']//*[text() = \'%ITEM%\']'; - -// edit variable popup -const editVariableTypeDropdown = '[data-testid=\'variable-type-dropdown--button\']'; -const editVariableTypeDropdownItem = '[data-testid=\'variable-type-dropdown-%ITEM%\']'; -const editVariableNameInput = '//*[@data-testid=\'form--element\'][.//*[text()=\'Name\']]//input'; -const editWarnVariablSubmit = '[data-testid=danger-confirmation-button]'; -const editVariableNameChangeSubmit = '[data-testid=rename-variable-submit]'; - -//Warning popup -const updateNameNameInput = '[data-testid=overlay--body] [data-testid=rename-variable-input]'; - - -class variablesTab extends settingsPage{ - - constructor(driver){ - super(driver); - } - - async isTabLoaded(){ - await super.isTabLoaded(urlCtx, - [ - {type: 'css', selector: variablesFilter}, - {type: 'css', selector: createVariableHeader}, - basePage.getSortTypeButtonSelector() - //{type: 'css', selector: nameSort}, - //{type: 'css', selector: typeSort}, - ] - ); - } - - async getVariablesFilter(){ - return await this.driver.findElement(By.css(variablesFilter)); - } - - async getCreateVariableHeader(){ - return await this.driver.findElement(By.css(createVariableHeader)); - } - - async getCreateVariableEmpty(){ - return await this.driver.findElement(By.css(createVariableEmpty)); - } - - async getCreateVariableItem(item){ - return await this.driver.findElement(By.css(createVariableItem.replace('%ITEM%', item))); - } - - async getPasteRadioButton(){ - return await this.driver.findElement(By.css(pasteRadioButton)); - } - - async getUploadRadioButton(){ - return await this.driver.findElement(By.css(uploadRadioButton)); - } - - async getDragNDropFile(){ - return await this.driver.findElement(By.css(dragNDropFile)); - } - - static getDragNDropFileSelector(){ - return { type: 'css', selector: dragNDropFile}; - } - - async getImportButton(){ - return await this.driver.findElement(By.css(importButton)); - } - - async getCreateVariableNameInput(){ - return await this.driver.findElement(By.css(createVariableNameInput)); - } - - async getCreateVariableTypeDropdown(){ - return await this.driver.findElement(By.css(createVariableTypeDropdown)); - } - - async getCreateVariableQueryCodeMirror(){ - return await this.driver.findElement(By.css(createVariableQueryCodeMirror)); - } - - static getCreateVariableQueryCodeMirrorSelector(){ - return {type: 'css', selector: createVariableQueryCodeMirror }; - } - - async getCreateVariableQueryMonacoEdit(){ - return await this.driver.findElement(By.css(createVariableQueryMonacoEdit)); - } - - static getCreateVariableQueryMonacoEditSelector(){ - return {type: 'css', selector: createVariableQueryMonacoEdit}; - } - - async getCreateVariableTextArea(){ - return await this.driver.findElement(By.css(createVariableTextArea)); - } - - static getCreateVariableTextAreaSelector(){ - return {type: 'css', selector: createVariableTextArea}; - } - - async getPasteJSONTextarea(){ - return await this.driver.findElement(By.css(pasteJSONTextarea)); - } - - static getPasteJSONTextareaSelector(){ - return { type: 'css', selector: pasteJSONTextarea}; - } - - async getCreateVariableTypeDropdownItem(item){ - return await this.driver.findElement(By.css(createVariableTypeDropdownItem - .replace('%ITEM%', item.toLowerCase()))); - } - - async getCreateVariableDefaultValDropdown(){ - return await this.driver.findElement(By.xpath(createVariableDefaultValDropdown)); - } - - static getCreateVariableDefaultValDropdownSelector(){ - return { type: 'xpath', selector: createVariableDefaultValDropdown}; - } - - async getCreateVariableInfoPara(){ - return await this.driver.findElement(By.xpath(createVariableInfoPara)); - } - - static getCreateVariableInfoParaSelector(){ - return { type: 'xpath', selector: createVariableInfoPara}; - } - - async getImportVariableDragNDropHeader(){ - return await this.driver.findElement(By.css(importVariableDragNDropHeader)); - } - - async getVariableCardNamed(name){ - return await this.driver.findElement(By.xpath(variableCardNamed.replace('%NAME%', name))); - } - - static getVariableCardSelectorByName(name){ - return { type: 'xpath', selector: variableCardNamed.replace('%NAME%', name)}; - } - - async getCreateVariableDefaultValDropdownItem(item){ - return await this.driver.findElement(By.css(createVariableDefaultValDropdownItem.replace('%ITEM%', item))); - } - - async getCreateVariableDefaultValCSVDropdownItem(item){ - return await this.driver.findElement(By.xpath(createVariableDefaultValCSVDropdownItem.replace('%ITEM%', item))); - } - - async getVariableCardNames(){ - return await this.driver.findElements(By.css(variableCardNames)); - } - - async getVariableCardName(name){ - return await this.driver.findElement(By.xpath(variableCardName.replace(/%NAME%/g, name))); - } - - async getNameSort(){ - return await this.driver.findElement(By.css(nameSort)); - } - - - async getVariableCardContextMenu(name){ - return await this.driver.findElement(By.xpath(variableCardContextMenu.replace('%NAME%', name))); - } - - async getVariableCardContextMenuItem(name, item){ - return await this.driver.findElement(By.xpath(variableCardContextMenuItem - .replace('%NAME%', name) - .replace('%ITEM%', item))); - } - - async getUpdateNameNameInput(){ - return await this.driver.findElement(By.css(updateNameNameInput)); - } - - async getEditVariableTypeDropdown(){ - return await this.driver.findElement(By.css(editVariableTypeDropdown)); - } - - - async getEditVariableTypeDropdownItem(item){ - return await this.driver.findElement(By.css(editVariableTypeDropdownItem.replace('%ITEM%', item.toLowerCase()))); - } - - async getEditVariableNameInput(){ - return await this.driver.findElement(By.xpath(editVariableNameInput)); - } - - async getVariableCardContextDelete(name){ - return await this.driver.findElement(By.xpath(variableCardContextDelete.replace('%NAME%', name))); - } - - async getVariableCardContextDeleteConfirm(name){ - return await this.driver.findElement(By.xpath(variableCardContextDeleteConfirm.replace('%NAME%', name))); - } - - async getEditVariablWarnSubmit(){ - return await this.driver.findElement(By.css(editWarnVariablSubmit)); - } - - async getEditVariableNameChangeSubmit(){ - return await this.driver.findElement(By.css(editVariableNameChangeSubmit)); - } - - async getCreateVarPopupCreateButton(){ - return await this.driver.findElement(By.css(createVarPopupCreateButton)); - } - -} - -module.exports = variablesTab; diff --git a/e2e/src/pages/signin/signinPage.js b/e2e/src/pages/signin/signinPage.js deleted file mode 100644 index 96f63bdfd0..0000000000 --- a/e2e/src/pages/signin/signinPage.js +++ /dev/null @@ -1,51 +0,0 @@ -const basePage = require(__srcdir + '/pages/basePage.js'); -const { By } = require('selenium-webdriver'); - -const heading = '.splash-page--heading'; -const influxLogo = '[data-testid=logo--influxdb-cloud]'; -const versionInfo = '.version-info p'; -const creditsLink = '.splash-page--credits a'; -const nameInput = 'input[name=username]'; //TODO - see if data-testid can be updated - currently 'input-field' for both name and password inputds -const passwordInput = 'input[name=password]'; //TODO - see if data-testid can be updated -const signinButton = '[data-testid=button]'; - -const urlCtx = 'signin'; - -class signinPage extends basePage{ - - constructor(driver){ - super(driver); - this.urlCtx = urlCtx; - } - - async getHeading(){ - return await this.driver.findElement(By.css(heading)); - } - - async getVersionInfo(){ - return await this.driver.findElement(By.css(versionInfo)); - } - - async getCreditsLink(){ - return await this.driver.findElement(By.css(creditsLink)); - } - - async getNameInput(){ - return await this.driver.findElement(By.css(nameInput)); - } - - async getPasswordInput(){ - return await this.driver.findElement(By.css(passwordInput)); - } - - async getSigninButton(){ - return await this.driver.findElement(By.css(signinButton)); - } - - async getInfluxLogo(){ - return await this.driver.findElement(By.css(influxLogo)); - } - -} - -module.exports = signinPage; diff --git a/e2e/src/pages/tasks/tasksPage.js b/e2e/src/pages/tasks/tasksPage.js deleted file mode 100644 index d5f792875e..0000000000 --- a/e2e/src/pages/tasks/tasksPage.js +++ /dev/null @@ -1,77 +0,0 @@ -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const basePage = require(__srcdir + '/pages/basePage.js'); -const { By } = require('selenium-webdriver'); - -const filterTasks = '[data-testid=search-widget]'; -const inactiveToggle = '[data-testid=slide-toggle]'; -const createTaskDropdownHeader = '[data-testid=page-control-bar--right] [data-testid=add-resource-dropdown--button]'; -const nameSortButton = '[data-testid=resource-list--sorter]:nth-of-type(1)'; -const activeSortButton = '[data-testid=resource-list--sorter]:nth-of-type(2)'; -const scheduleSortButton = '[data-testid=resource-list--sorter]:nth-of-type(3)'; -const lastCompletedSortButton = '[data-testid=resource-list--sorter]:nth-of-type(4)'; -// following is only present until first task is created, so not good candidate for isLoaded check -const createTaskDropdownBody = '[data-testid=resource-list--body] [data-testid=add-resource-dropdown--button]'; - -const taskCardByName = '//*[@data-testid=\'task-card\'][.//span[text() = \'%NAME%\']]'; - - -const urlCtx = 'tasks'; - -class tasksPage extends influxPage{ - - constructor(driver){ - super(driver); - } - - async isLoaded(){ - await super.isLoaded([{type: 'css', selector: filterTasks}, - {type: 'css', selector: inactiveToggle} , - {type: 'css', selector: createTaskDropdownHeader} , - // {type: 'css', selector: nameSortButton}, - basePage.getSortTypeButtonSelector(), - //{type: 'css', selector: activeSortButton}, - //{type: 'css', selector: scheduleSortButton}, - //{type: 'css', selector: lastCompletedSortButton} - ], urlCtx); - } - - async getFilterTasks(){ - return await this.driver.findElement(By.css(filterTasks)); - } - - async getInactiveToggle(){ - return await this.driver.findElement(By.css(inactiveToggle)); - } - - async getCreateTaskDropdownHeader(){ - return await this.driver.findElement(By.css(createTaskDropdownHeader)); - } - - async getNameSortButton(){ - return await this.driver.findElement(By.css(nameSortButton)); - } - - async getActiveSortButton(){ - return await this.driver.findElement(By.css(activeSortButton)); - } - - async getScheduleSortButton(){ - return await this.driver.findElement(By.css(scheduleSortButton)); - } - - async getLastCompetedSortButton(){ - return await this.driver.findElement(By.css(lastCompletedSortButton)); - } - - async getCreateTaskDropdownBody(){ - return await this.driver.findElement(By.css(createTaskDropdownBody)); - } - - async getTaskCardByName(name){ - return await this.driver.findElement(By.xpath(taskCardByName.replace('%NAME%', name))); - } - -} - -module.exports = tasksPage; - diff --git a/e2e/src/step_definitions/common/cloudStepDefs.js b/e2e/src/step_definitions/common/cloudStepDefs.js deleted file mode 100644 index 4360cf1ce9..0000000000 --- a/e2e/src/step_definitions/common/cloudStepDefs.js +++ /dev/null @@ -1,42 +0,0 @@ -import { AfterAll, Given, Then, When } from 'cucumber'; -const cloudSteps = require(__srcdir + '/steps/cloudSteps.js'); - -let cSteps = new cloudSteps(__wdriver); - -When(/^open the cloud page in "(.*?)" milliseconds$/, {timeout: 15000}, async (maxDelay) => { - await cSteps.openCloudPage(parseInt(maxDelay)); -}); - -/* -When(/^setup default cloud user$/, async () => { - await cSteps.setupDefaultCloudUser(); -}); -*/ - -When(/^I open the cloud login$/, {timeout: 30000}, async () => { - await cSteps.openCloudLogin(); -}); - -When(/^log in to the cloud$/, async () => { - await cSteps.logInToCloud(); -}); - -When(/^log in to the cloud in "(.*)" milliseconds$/, {timeout: 15000}, async (maxDelay) => { - await cSteps.logInToCloudTimed(parseInt(maxDelay)); -}); - -When(/^I logout to account info in "(.*)" milliseconds$/, {timeout: 15000}, async (maxDelay) => { - await cSteps.logoutToAccountInfoTimed(parseInt(maxDelay)); -}); - -When(/^I logout to login page in "(.*)" milliseconds$/, {timeout: 15000}, async(maxDelay) => { - await cSteps.logoutToLoginTimed(parseInt(maxDelay)); -}); - -When(/^wait "(.*?)" with delay "(.*?)"$/, async (sleep, delay) => { - await cSteps.performanceBogusTest(sleep, parseInt(delay)); -}); - -Then(/^the cloud login page is loaded$/, {timeout: 15000}, async () => { - await cSteps.verifyCloudLoginPageLoaded(); -}); diff --git a/e2e/src/step_definitions/common/commonStepDefs.js b/e2e/src/step_definitions/common/commonStepDefs.js deleted file mode 100644 index c2052e330f..0000000000 --- a/e2e/src/step_definitions/common/commonStepDefs.js +++ /dev/null @@ -1,414 +0,0 @@ -import { AfterAll, Given, Then, When } from 'cucumber'; -import {flush} from '../../utils/influxUtils'; -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const signinSteps = require(__srcdir + '/steps/signin/signinSteps.js'); -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -let bSteps = new baseSteps(__wdriver); -let sSteps = new signinSteps(__wdriver); -let iSteps = new influxSteps(__wdriver); - -Given(/^I reset the environment$/, async () => { - await bSteps.driver.sleep(1000); //since gets called after scenarios, need a short delay to avoid promise resolution issues - await bSteps.resetEnvironment(); - //await flush(); -}); - -/* -Before(() => { -}) - -BeforeAll(() => { -}) - -After(() => { - console.log("DEBUG After hook") -}) -*/ - -AfterAll(async() => { - await bSteps.driver.close(); -}); - -When(/^clear browser storage$/, async () => { - await bSteps.clearBrowserLocalStorage(); -}); - -Then(/^the success notification says "(.*?)"$/, async message => { - await bSteps.isNotificationMessage(message); -}); - -Then(/^the success notification contains "(.*?)"$/, async text => { - //can be used in template or outline - some cases may needed to be skipped - if(text.toLowerCase() !== 'skip') { - await bSteps.containsNotificationText(text); - } -}); - -Then(/^the primary notification contains "(.*)"$/, async text => { - if(text.toLowerCase() !== 'skip') { - await bSteps.containsPrimaryNotificationText(text); - } -}); - -Then(/^the error notification contains "(.*?)"$/, async text => { - await bSteps.containsErrorNotificationText(text); -}); - -When(/^close all notifications$/, async() => { - await bSteps.closeAllNotifications(); -}); - -// newUser if not DEFAULT should follow {username: 'name', password: 'password', org: 'org', bucket: 'bucket'} -Given(/^run setup over REST "(.*?)"$/, async( newUser ) => { - - //await influxUtils.flush(); - - if(newUser === 'DEFAULT'){ - await influxUtils.setupUser(__defaultUser); - }else{ - let user = JSON.parse(newUser); - if(user.password.length < 8 ){ - throw Error(`Password: ${user.password} is shorter than 8 chars`); - } - await influxUtils.setupUser(user); - } - -}); - -Given(/^run setup user "(.*)"$/, {timeout: 15000}, async newUser => { - await influxUtils.setupNewUser(newUser); -}); - -Given(/^run setup over CLI docker "(.*?)"$/, async( newUser ) => { - - if(newUser === 'DEFAULT'){ - await influxUtils.setupUserDockerCLI(__defaultUser); - }else{ - let user = JSON.parse(newUser); - if(user.password.length < 8 ){ - throw Error(`Password: ${user.password} is shorter than 8 chars`); - } - await influxUtils.setupUser(user); - } - - await bSteps.driver.sleep(1000); //give system chance to write everything down - -}); - -When(/^API sign in user "(.*?)"$/, async username => { - await influxUtils.signInAxios((username === 'DEFAULT') ? __defaultUser.username : username).then(async () => { - // await sSteps.driver.sleep(1500) - - }).catch(async err => { - console.log('ERROR ' + err); - throw(err); - }); -}); - -When(/^API end session$/, async() => { - await influxUtils.endSession(); -}); - -When(/^UI sign in user "(.*?)"$/, {timeout: 15000}, async username => { - let user = influxUtils.getUser((username === 'DEFAULT') ? __defaultUser.username : username); - await sSteps.signin(user); - //await sSteps.driver.sleep(1500) -}); - -When(/^write basic test data for org "(.*?)" to bucket "(.*?)"$/, async (org,bucket) => { - await influxUtils.writeData(org,bucket); -}); - -When(/^write sine data for org "(.*?)" to bucket "(.*?)"$/, async (org, bucket) =>{ - - let nowNano = new Date().getTime() * 1000000; - - let intervalNano = 600 * 1000 * 1000000; //10 min in nanosecs - - let lines = []; - - let recCount = 256; - - let startTime = nowNano - (recCount * intervalNano); - - for(let i = 0; i < recCount; i++){ - lines[i] = 'sinus point=' + Math.sin(i) + ' ' + (startTime + (i * intervalNano)); - } - - console.log('DEBUG lines: '); - lines.forEach((line) => { - console.log(line); - }); - - await influxUtils.writeData(org, bucket, lines); - -}); - -//For Inspection purposes -When(/^simple query data "(.*)" for org of user "(.*)" from bucket "(.*)" over "(.*)"$/, async (items, userName, bucket, period) => { - - let dataDef = JSON.parse(items.replace(/\\/g,"")); - let targetBucket = (bucket === 'DEFAULT') ? __defaultUser.bucket : 'fred'; - let query = `from(bucket: "${targetBucket}") - |> range(start: ${period}) - |> filter(fn: (r) => r._measurement == "${dataDef.name}") - |> filter(fn: (r) => r._field == "${dataDef.measurement}")`; - - let results = await influxUtils.query(userName, query); - console.info('INFO results: ' + JSON.stringify(results)); -}); - - -When(/^API create a dashboard named "(.*?)" for user "(.*?)"$/, async (name, username) => { - - let user = await influxUtils.getUser(username); - - let dashb = await influxUtils.createDashboard(name, user.orgid); - - if(user.dashboards === undefined){ - user.dashboards = new Object(); - } - - //Save dashboard for later use - user.dashboards[name] = dashb; - -}); - -//Troubleshoot method -When(/^API get all dashboards for user "(.*?)"$/, async user => { - - let dboards = await influxUtils.getDashboards(user); - - console.info(`DUMP dboards for user (${user}):\n ${JSON.stringify(dboards)}`); - -}); - - - -When(/^API create a bucket named "(.*)" for user "(.*)"$/, async (bucket, username) => { - let user = await influxUtils.getUser((username === 'DEFAULT') ? __defaultUser.username : username); - await influxUtils.createBucket(user.orgid, user.org, bucket); -}); - -When(/^API create a label "(.*)" described as "(.*)" with color "(.*)" for user "(.*)"$/, - async (labelName, labelDescr, labelColor, userName) => { - await influxUtils.createLabel(userName, labelName, labelDescr, labelColor); - }); - -When(/^open page "(.*?)" for user "(.*?)"$/, async (page, username) => { - - let user = await influxUtils.getUser((username === 'DEFAULT') ? __defaultUser.username : username); - let ctx = 'orgs/' + user.orgid; - if(page !== 'HOME'){ - ctx += `/${page}`; - } - - await bSteps.openContext(ctx); - - await iSteps.isLoaded(); - //await bSteps.driver.sleep(3000) - -}); - -Then(/^the form element error message is "(.*)"$/, async msg => { - await bSteps.verifyElementErrorMessage(msg); -}); - -Then(/^the form element error message is not shown$/, async () => { - await bSteps.verifyNoElementErrorMessage(); -}); - -Then(/^no form input error icon is shown$/, async () => { - await bSteps.verifyNoFormInputErrorIcon(); -}); - -Then(/^a form input error icon is shown$/, async () => { - await bSteps.verifyInputErrorIcon(); -}); - -When(/^click the Popup Wizard continue button$/, {timeout: 15000}, async() => { - await bSteps.clickPopupWizardContinue(); - //await bSteps.driver.sleep(10000); -}); - -When(/^click the wizard previous button$/, async () => { - await bSteps.clickPopupWizardPrevious(); -}); - -When(/^click the Popup Wizard done button$/, async () => { - await bSteps.clickPopupWizardContinue(); -}); - -Then(/^the popup wizard continue button is disabled$/, async() => { - await bSteps.verifyWizardContinueButtonDisabled(); -}); - -When(/^dismiss the popup$/, async () => { - await bSteps.dismissPopup(); -}); - -When(/^click popup cancel button$/, async () => { - await bSteps.clickPopupCancelBtn(); -}); - -When(/^click popup cancel simple button$/, async () => { - await bSteps.clickPopupCancelBtnSimple(); -}); - - -Then(/^popup is not loaded$/, async () => { - await bSteps.verifyPopupNotPresent(); -}); - -When(/^click popup submit button$/, async () => { - await bSteps.clickPopupSubmitButton(); -}); - -Then(/^the popup wizard step state text contains "(.*)"$/, async text => { - await bSteps.verifyPopupWizardStepStateText(text); -}); - -Then(/^the popup wizard step is in state "(.*)"$/, async state => { - await bSteps.verifyPopupWizardStepState(state); -}); - -Then(/^the popup wizard import file header contains "(.*)"$/, async text => { - await bSteps.verifyPopupFileUploadHeaderText(text); -}); - -When(/^generate a line protocol testdata file "(.*)" based on:$/, async (filePath, def) => { - await influxUtils.genLineProtocolFile(filePath, def); -}); - -When(/^generate a line protocol testdata for user "(.*)" based on:$/, async (userName, def) => { - - //await influxUtils.writeLineProtocolData((user === 'DEFAULT')? __defaultUser: await influxUtils.getUser(user), - // def); - - await influxUtils.writeLineProtocolData(userName, def); -}); - -When(/^create the "(.*)" variable "(.*)" with default "(.*)" for user "(.*)" with values:$/, - async(type, name, defVal, userName, values) => { - type = type === 'csv' ? 'constant' : type.toLowerCase(); - //let orgID = influxUtils.getUser((user === 'DEFAULT') ? __defaultUser.username : user).orgid; - await influxUtils.createVariable(userName, name, type, values, defVal) -}); - -//For troubleshooting - up to 5 min -When(/^wait "(.*)" seconds$/, {timeout: 5 * 60 * 1000}, async secs => { - await bSteps.driver.sleep(parseInt(secs) * 1000); -}); - -When(/^force page refresh$/, async ()=> { - await bSteps.driver.navigate().refresh(); -}); - -When(/^press the "(.*)" key$/, async key => { - await bSteps.pressKeyAndWait(key); -}); - -When(/^create a new template from the file "(.*)" for user "(.*)"$/, async (filepath, userName) => { - //let orgID = influxUtils.getUser((user === 'DEFAULT') ? __defaultUser.username : user).orgid; - await influxUtils.createTemplateFromFile(userName, filepath); -}); - -When(/^create check over API from file "(.*)" for user "(.*)"$/, async (filepath, userName) => { - //let orgID = influxUtils.getUser((user === 'DEFAULT') ? __defaultUser.username : user).orgid; - await influxUtils.createAlertCheckFromFile(userName, filepath); -}); - -When(/^remove file "(.*)" if exists$/, async filePath => { - await influxUtils.removeFileIfExists(filePath); -}); - -Then(/^the file "(.*)" has been downloaded$/, async filePath => { - await bSteps.verifyFileExists(filePath); -}); - -When(/^remove files "(.*)" if exists$/, async regex => { - await influxUtils.removeDownloadFilesByRegex(regex); -}); - -Then(/^a file matching "(.*)" exists$/, async regex => { - await bSteps.verifyDownloadFileMatchingRegexExists(regex); -}); - -When(/^verify first CSV file matching "(.*)" as containing$/, async (path, dataDesc) => { - let datdescr = JSON.parse(dataDesc); - await bSteps.verifyFirstCSVFileMatching(path, datdescr); -}); - -When(/^get console log$/, async () => { - await bSteps.getConsoleLog(); -}); - -When(/^write message "(.*)" to console log$/, async msg => { - await bSteps.writeMessageToConsoleLog(msg); -}); - -When(/^send keys "(.*)"$/, async keys => { - await bSteps.sendKeysToCurrent(keys); -}); - -When(/^start live data generator$/, async def => { - bSteps.startLiveDataGenerator(def); -}); - -When(/^stop live data generator$/, async () => { - bSteps.stopLiveDataGenerator(); -}); - -When(/^click the sort type dropdown$/, async () => { - await bSteps.clickSortTypeDropdown(); -}); - -When(/^click sort by item "(.*)"$/, async item => { - await bSteps.clickSortByListItem(item); -}); - -Then(/^the add label popover is not present$/, async () => { - await bSteps.verifyAddLabelsPopopverNotPresent(); -}); - -Then(/^the add label popover is present$/, async () => { - await bSteps.verifyAddLabelPopoverVisible(); -}); - -Then(/^the add label popover contains the labels$/, async labels => { - await bSteps.verifyLabelPopoverContainsLabels(labels); -}); - -When(/^click the label popover item "(.*)"$/, async item => { - await bSteps.clickLabelPopoverItem(item); -}); - -Then(/^the add label popover does not contain the labels:$/, { timeout: 10000}, async labels => { - await bSteps.verifyLabelPopoverDoesNotContainLabels(labels); -}); - -When(/^set the label popover filter field to "(.*)"$/, async val => { - await bSteps.setLabelPopoverFilter(val); -}); - -Then(/^the label popover contains create new "(.*)"$/, async name => { - await bSteps.verifyLabelPopoverCreateNew(name); -}); - -Then(/^the add label popover does not contain create new$/, async () => { - await bSteps.verifyLabelPopupNoCreateNew(); -}); - -When(/^clear the popover label selector filter$/, async () => { - await bSteps.clearDashboardLabelsFilter(); -}); - -//For Inspection -When(/^get authorizations for user "(.*)"$/, async userName => { - let auths = await influxUtils.getAuthorizations(userName); - console.info(`Authorizations for ${userName}:\n${JSON.stringify(auths)}`); -}); - - diff --git a/e2e/src/step_definitions/dashboards/cellOverlayStepDefs.js b/e2e/src/step_definitions/dashboards/cellOverlayStepDefs.js deleted file mode 100644 index 7b190071e9..0000000000 --- a/e2e/src/step_definitions/dashboards/cellOverlayStepDefs.js +++ /dev/null @@ -1,598 +0,0 @@ -import { Then, When } from 'cucumber'; -const cellOverlaySteps = require(__srcdir + '/steps/dashboards/cellOverlaySteps.js'); - -let celOvSteps = new cellOverlaySteps(__wdriver); - -Then(/^the cell edit overlay is loaded as "(.*)"$/, {timeout: 10000}, async name => { - await celOvSteps.verifyCellOverlayIsLoaded(name); -}); - -When(/^get the current cell edit preview graph$/, async () => { - await celOvSteps.getCurrentCellEditPreviewGraph(); -}); - -When(/^name dashboard cell "(.*)"$/, async name => { - await celOvSteps.nameDashboardCell(name); -}); - -When(/^click dashboard cell edit cancel button$/, async () => { - await celOvSteps.clickDashboardCellEditCancel(); -}); - -When(/^click dashboard cell save button$/, async () => { - await celOvSteps.clickDashboardCellSave(); -}); - -When(/^click the cell edit Time Range Dropdown$/, async () => { - await celOvSteps.clickCellEditTimeRangeDropdown(); -}); - -When(/^select the cell edit Time Range "(.*)"$/, async item => { - await celOvSteps.selectCellEditTimeRangeItem(item); -}); - -When(/^click the cell edit Script Editor button$/, async () => { - await celOvSteps.clickCellEditScriptEditorButton(); -}); - -When(/^paste into cell edit Script Editor$/, { timeout: 20000 }, async text => { - await celOvSteps.pasteIntoCellEditScriptEditor(text); -}); - -When(/^clear the cell edit Script Editor$/, { timeout: 20000 }, async () => { - await celOvSteps.clearCellEditScriptEditor(); -}); - -Then(/^the time machine cell edit submit button is disabled$/, async () => { - await celOvSteps.verifyCellEditSubmitDisabled(); -}); - -Then(/^the time machine cell edit submit button is enabled$/, async () => { - await celOvSteps.verifyCellEditSubmitEnabled(); -}); - -When(/^click the time machine cell edit submit button$/, async () => { - await celOvSteps.clickCellEditSubmitButton(); -}); - -Then(/^the time machine cell edit preview graph is shown$/, async() => { - await celOvSteps.verifyCellEditPreviewGraphVisible(); -}); - -Then(/^the time machine cell edit preview axes are shown$/, async() => { - await celOvSteps.verifyCellEditPreviewAxesVisible(); -}); - -Then(/^the cell edit preview graph is changed$/, async() => { - await celOvSteps.verifyCellEditPreviewGraphChanged(); -}); - -When(/^click the cell edit save button$/, async () => { - await celOvSteps.clickCellEditSaveButton(); -}); - -When(/^click on the cell edit name$/, async () => { - await celOvSteps.clickCellEditName(); -}); - -When(/^change the cell edit name to "(.*)"$/, async name => { - await celOvSteps.updateCellName(name); -}); - -When(/^click the dashboard cell view type dropdown$/, async () => { - await celOvSteps.clickViewTypeDropdown(); -}); - -Then(/^the dashboard cell view type dropdown list contains:$/, async itemList => { - await celOvSteps.verifyViewTypeListContents(itemList); -}); - -Then(/^the cell view type dropdown list is not present$/, async () => { - await celOvSteps.verifyViewTypeListNotPresent(); -}); - -When(/^click cell view customize button$/, async () => { - await celOvSteps.clickCellViewCustomize(); -}); - -Then(/^the view options container is present$/, async () => { - await celOvSteps.verifyViewOptionsContainerVisible(); -}); - -Then(/^the view options container is not present$/, async () => { - await celOvSteps.verifyViewOptionsContainerNotPresent(); -}); - -Then(/^the cell view customize button is highlighted$/, async () => { - await celOvSteps.verifyCellCustomizeButtonHighlight(); -}); - -Then(/^the cell view customize button is not highlighted$/, async () => { - await celOvSteps.verifyCustomizeButtonNoHighlightd(); -}); - -Then(/^the time machine view empty queries graph is visible$/, async () => { - await celOvSteps.verifyTMViewEmptyQueriesGraphVisible(); -}); - -Then(/^the time machine view no results is visible$/, async () => { - await celOvSteps.verifyTMViewNoResultsVisible(); -}); - -When(/^click time machine autorefresh dropdown$/, async () => { - await celOvSteps.clickTMAutorefreshDropdown(); -}); - -Then(/^the time machine autorefresh dropdown list contains:$/, async itemList => { - await celOvSteps.verifyAutorefreshListContents(itemList); -}); - -When(/^select the time machine autorefresh rate "(.*)"$/, async item => { - await celOvSteps.clickTMAutorefreshItem(item); -}); - -Then(/^the time machine force refresh button is not present$/, async () => { - await celOvSteps.verifyTMAutorefreshForceButtonNotPresent(); -}); - -Then(/^the time machine force refresh button is present$/, async () => { - await celOvSteps.verifyTMAutorefreshForceButtonVisible(); -}); - -Then(/^the time machine autorefresh dropdown list is set to "(.*)"$/, async selected => { - await celOvSteps.verifyTMAutorefreshDropdownSelected(selected); -}); - -When(/^click time machine force refresh$/, async () => { - await celOvSteps.clickTMForceRefresh(); -}); - -Then(/^the time machine Time Range dropdown list contains:$/, async itemList => { - await celOvSteps.verifyTMTimeRangeDropdownList(itemList); -}); - -Then(/^the time machine Time Range dropdown list is not present$/, async () => { - await celOvSteps.verifyTMTimeRangeDropdownListNotPresent(); -}); - -Then(/^the time machine query builder is visible$/, async () => { - await celOvSteps.verifyTMQueryBuilderVisible(); -}); - -Then(/^the time machine switch to Query Builder warning is present$/, async () => { - await celOvSteps.verifyTMQueryBuilderSwitchWarnVisible(); -}); - -Then(/^the time machine switch to Query Builder warning is not present$/, async () => { - await celOvSteps.verifyTMQueryBuilderSwitchWarnNotPresent(); -}); - -Then(/^the time machine flux editor is visible$/, async () => { - await celOvSteps.verifyTMFluxEditorVisible(); -}); - -When(/^click the cell edit Query Builder button$/, async () => { - await celOvSteps.clickTMSwitch2QBuilder(); -}); - -When(/^click the cell edit Query Builder confirm button$/, async () => { - await celOvSteps.clickTMSwitch2QBuilderConfirm(); -}); - -When(/^click the time machine flux editor$/, async () => { - await celOvSteps.clickTMFluxEditor(); -}); - -When(/^click the filter functions input$/, async () => { - await celOvSteps.clickTMFilterFunctionsInput(); -}); - -Then(/^the time machine flux editor is not present$/, async () => { - await celOvSteps.verifyTMFluxEditorNotPresent(); -}); - -Then(/^the edit cell bucket selector contains buckets:$/, async bucketList => { - await celOvSteps.verifyTMBucketListContents(bucketList); -}); - -When(/^click the time machine bucket selector item "(.*)"$/, async item => { - await celOvSteps.driver.sleep(500); //troubleshoot issue with click on wrong item - await celOvSteps.clickTMBucketSelectorItem(item); -}); - -Then(/^the bucket "(.*)" is not present in the time machine bucket selector$/, async bucket => { - await celOvSteps.verifyBucketNotInTMBucketList(bucket); -}); - -When(/^filter the time machine bucket selector with "(.*)"$/, async value => { - await celOvSteps.filterBucketListContents(value); -}); - -When(/^clear the time machine bucket selector filter$/, async () => { - await celOvSteps.clearBucketSelectorFilter(); -}); - -Then(/^there are "(.*)" time machine builder cards$/, async count => { - await celOvSteps.verifyTMBuilderCardsSize(count); -}); - -Then(/^time machine builder card "(.*)" contains:$/, async (index,items) => { - await celOvSteps.verifyItemsInBuilderCard(index,items); -}); - -Then(/^the item "(.*)" in builder card "(.*)" is selected$/, async (item,index) => { - await celOvSteps.verifyItemSelectedInBuilderCard(index, item); -}) - -Then(/^time machine builder card "(.*)" contains the empty tag message$/, async index => { - await celOvSteps.verifyEmptyTagsInBuilderCard(index); -}); - -Then(/^there are no selected tags in time machine builder card "(.*)"$/, async index => { - await celOvSteps.verifyNoSelectedTagsInBuilderCard(index); -}); - -Then(/^the selector count for builder card "(.*)" contains the value "(.*)"$/, async (index,value) =>{ - await celOvSteps.verifySelectorCountInBuilderCard(index,value); -}); - -Then(/^time machine builder card "(.*)" does not contain "(.*)"$/, async (index, item) => { - await celOvSteps.verifyItemNotInBuilderCard(index,item); -}); - -When(/^click the tag selector dropdown of builder card "(.*)"$/, async index => { - await celOvSteps.clickTagSelectorOfBuilderCard(index); -}); - -Then(/^the tag selector dropdown of builder card "(.*)" contains:$/, async (index,items) => { - await celOvSteps.verifyItemsInBuilderCardTagSelector(index,items); -}); - -When(/^click the tag selector dropdown item "(.*)" of builder card "(.*)"$/, async (item, index) => { - await celOvSteps.clickTagSelectorDropdownItemInBuilderCard(item,index); -}); - -When(/^click the tag "(.*)" in builder card "(.*)"$/, async (tag, cardIndex) => { - await celOvSteps.clickTagInBuilderCard(tag, cardIndex); -}); - -When(/^filter the tags in time machine builder card "(.*)" with "(.*)"$/, {timeout: 10000}, async (index,term) => { - await celOvSteps.filterBuilderCardListContents(index,term); -}); - -Then(/^time machine builder card "(.*)" is empty$/, async index => { - await celOvSteps.verifyBuilderCardEmpty(index); -}); - -When(/^clear the tags filter in time machine builder card "(.*)"$/, async index => { - await celOvSteps.clearTagsFilterInBuilderCard(index); -}); - -Then(/^the contents of tag selector dropodwn of build card "(.*)" are not present$/, async index => { - await celOvSteps.verifyBuilderCardTagSelectNotPresent(index); -}); - -Then(/^the selector counf for builder card "(.*)" is not present$/, async index => { - await celOvSteps.verifyBuilderCardSelectCountNotPresent(index); -}); - -Then(/^the delete button for builder card "(.*)" is not present$/, async index => { - await celOvSteps.verifyBuilderCardDeleteNotPresent(index); -}); - -When(/^click delete for builder card "(.*)"$/, async index => { - await celOvSteps.clickBuilderCardDelete(index); -}); - -Then(/^the time machine query builder function duration period is "(.*)"$/, async duration => { - await celOvSteps.verifyTMQueryBuilderFunctionDuration(duration); -}); - -When(/^click the custom function group$/, async () => { - await celOvSteps.clickCustomFunctionGroup(); -}); - -When(/^click the time machine query builder function duration input$/, async () => { - await celOvSteps.clickTMQueryBuilderFunctionDuration(); -}); - -When(/^click the time machine query builder function custom duration tab$/, async () => { - await celOvSteps.clickTMQueryBuilderCustomDuration(); -}); - -When(/^click the time machine query builder function auto duration tab$/, async () => { - await celOvSteps.clickTMQueryBuilderAutoDuration(); -}); - -Then(/^the query builder function duration suggestion drop down contains "(.*)" suggestions$/, async count => { - await celOvSteps.verifyTMQBFunctionDurationSuggestionCount(count); -}); - -Then(/^the query builder function duration suggestion drop down includes$/, async items => { - await celOvSteps.verifyTMQBFunctionDurationSuggestionItems(items); -}); - -When(/^click the query builder function duration suggestion "(.*)"$/, async item => { - await celOvSteps.clickTMQBFunctionDurationSuggestionItem(item); -}); - -Then(/^the query builder function list contains$/, async items => { - await celOvSteps.verifyTMQueryBuilderFunctionListItems(items); -}); - -Then(/^the query builder function list has "(.*)" items$/, async count => { - await celOvSteps.verifyQuerBuilderFunctionListItemCount(count); -}); - -When(/^filter the query builder function list with "(.*)"$/, async term => { - await celOvSteps.filterQueryBuilderFunctionList(term); -}); - -When(/^clear the query builder function lis filter$/, async () => { - await celOvSteps.clearQueryBuilderFunctionListFilter(); -}); - -When(/^get metrics of time machine cell edit preview$/, async () => { - await celOvSteps.getTMPreviewMetrics(); -}); - -When(/^get metrics of time machine query builder$/, async () => { - await celOvSteps.getTMPQueryAreaMetrics(); -}); - -When(/^get time machine preview canvas$/, async () => { - await celOvSteps.getTMPreviewCanvas(); -}); - -When(/^get time machine preview axes$/, async () => { - await celOvSteps.getTMPreviewCanvasAxes(); -}); - -When(/^resize time machine preview area by "(.*)"$/, async dims => { - let deltaSize = JSON.parse(dims); - await celOvSteps.resizeTMPreviewBy(deltaSize); -}); - -Then(/^the time machine preview area has changed by "(.*)"$/, async dims => { - let deltaSize = JSON.parse(dims); - await celOvSteps.verifyTMPreviewAreaSizeChange(deltaSize); -}); - -Then(/^the time machine query builder area has changed by "(.*)"$/, async dims => { - let deltaSize = JSON.parse(dims); - await celOvSteps.verifyTMQBAreaSizeChange(deltaSize); -}); - -Then(/^the time machine preview canvas has changed$/, {timeout: 10000}, async () => { - await celOvSteps.verifyTMPreviewCanvasChange(); -}); - -Then(/^the time machine preview canvas has not changed$/, {timeout: 1000}, async () => { - await celOvSteps.verifyTMPreviewCanvasNoChange(); -}); - -Then(/^the time machine preview axes have changed$/, async () => { - await celOvSteps.verifyTMPreviewAxesChange(); -}); - -Then(/^the time machine preview canvas is not present$/, async () => { - await celOvSteps.verifyTMPreviewCanvasNotPresent(); -}); - -Then(/^the time machine preview canvas axes are not present$/, async () => { - await celOvSteps.verifyTMPreviewCanvasAxesNotPresent(); -}); - -When(/^click the time machine query builder add query button$/, async () => { - await celOvSteps.clickTMAddQuery(); -}); - -Then(/^the bucket selected in the current time machine query is "(.*)"$/, async bucket => { - await celOvSteps.verifyTMQueryBucketSelected(bucket); -}); - -Then(/^the tag selected in the current time machine query card "(.*)" is "(.*)"$/, async (index, tag) => { - await celOvSteps.verifyTMQueryCardSelected(index,tag); -}); - -Then(/^the functions selected in the current time machine query card are "(.*)"$/, async funcs => { - await celOvSteps.verifyTMQueryFunctionsSelected(funcs); -}); - -When(/^click the query builder function "(.*)"$/, async func => { - await celOvSteps.clickTMQBFunction(func); -}); - -Then(/^query "(.*)" is the active query in query builder$/, async title => { - await celOvSteps.verifyTMQBActiveQuery(title); -}); - -When(/^click on query "(.*)" in the query builder$/, async title => { - await celOvSteps.clickOnTMQBQueryTab(title); -}); - -When(/^right click on the time machine query tab title "(.*)"$/, async title => { - await celOvSteps.rightClickTMQBQueryTabTitle(title); -}); - -When(/^click the time machine query tab right click menu item "(.*)"$/, async item => { - await celOvSteps.clickTMQBQueryTabRightClickMenuItem(item); -}); - -When(/^enter "(.*)" into the time machine query tab name input$/, async name => { - await celOvSteps.enterNewTMQBQueryTabName(name); -}); - -Then(/^there is no time machine query tab named "(.*)"$/, async name => { - await celOvSteps.verifyNoTMQBQueryTabNamed(name); -}); - -When(/^click hide query of time machine query tab "(.*)"$/, async name => { - await celOvSteps.clickTMQBHideQuery(name); -}); - -When(/^right click the time machine query tab "(.*)"$/, async name => { - await celOvSteps.clickRightTMQBQuery(name); -}); - -When(/^click delete of time machine query tab "(.*)"$/, async name => { - await celOvSteps.clickTMQBDeleteQuery(name); -}); - -Then(/^there are "(.*)" time machine query tabs$/, async count => { - await celOvSteps.verifyTMQBNumberOfQueryTabs(count); -}); - -Then(/^the time machine script editor contains$/, async script => { - await celOvSteps.verifyTMQBScriptEditorContents(script); -}); - -When(/^change the time machine script editor contents to:$/, { timeout: 60000 }, async script => { - await celOvSteps.updateTMQBScriptEditorContents(script); -}); - -When(/^set the time machine script editor contents to:$/, {timeout: 60000}, async script => { - await celOvSteps.updateTMQBScriptEditorContents(script); -}); - -When(/^click the time machine switch to query builder button$/, async () => { - await celOvSteps.clickTMSwitch2QBuilder(); -}); - -Then(/^the time machine empty graph error message is:$/, async msg => { - await celOvSteps.verifyTMEmptyGraphErrorMessage(msg); -}); - -When(/^close all time machine builder cards$/, async () => { - await celOvSteps.closeAllTMQBCards(); -}); - -When(/^unselect any tags in time machine builder card "(.*)"$/, async index => { - await celOvSteps.deselectAllActiveTagsInTMQBCard(index); -}); - -Then(/^the time machine query edit function categories are displayed:$/, async cats => { - await celOvSteps.verifyTMQEFunctionCategoriesDisplayed(cats); -}); - -When(/^filter the time machine query edit function list with "(.*)"$/, async term => { - await celOvSteps.filterTMQEFunctionsList(term); -}); - -When(/^clear the time machine query edit function list filter$/, async () => { - await celOvSteps.clearTMQEFunctionsListFilter(); -}); - -Then(/^the following function are visible in the time machine function list:$/, async funcs => { - await celOvSteps.verifyTMQEVisibleFunctions(funcs); -}); - -Then(/^the following function are not visible in the time machine function list:$/, {timeout: 20000}, async funcs => { - await celOvSteps.verifyTMQENotVisibleFunctions(funcs); -}); - -When(/^click the time machine query editor function "(.*)"$/, async func => { - await celOvSteps.clickTMQEFunction(func); -}); - -When(/^click inject the time machine query editor function "(.*)"$/, async func => { - await celOvSteps.clickInjectTMQEFunction(func); -}); - -When(/^hover over time machine query edit function "(.*)"$/, async func => { - await celOvSteps.hoverOverTMQEFunction(func); -}); - -Then(/^the time machine query edit function popup description contains:$/, async text => { - await celOvSteps.verifyTMQEFunctionPopupDescription(text); -}); - -Then(/^the time machine query edit function popup snippet contains:$/, async text => { - await celOvSteps.verifyTMQEFunctionPopupSnippet(text); -}); - -Then(/^the time machine query edit function popup is not visible$/, async () => { - await celOvSteps.verifyTMQEFunctionPopupNotVisible(); -}); - -When(/^hover over the time machine query editor timerange dropdown button$/, async () => { - await celOvSteps.hoverOverTMQETimerangeDropdown(); -}); - -When(/^hover over the time machine query editor submit button$/, async() => { - await celOvSteps.hoverOverTMCellEditSubmit(); -}); - -When(/^send keys "(.*)" to the time machine flux editor$/, async keys => { - await celOvSteps.sendKeysToTimeMachineFluxEditor(keys); -}); - -Then(/^the time machine raw data table is not present$/, async () => { - await celOvSteps.verifyTMRawDataTableNotPresent(); -}); - -Then(/^the time machine raw data table is present$/, async () => { - await celOvSteps.verifyTMRawDataTablePresent(); -}); - -When(/^click time machine raw data toggle$/, async () => { - await celOvSteps.clickTMRawDataToggle(); -}); - -Then(/^time machine raw data cell "(.*)" contains "(.*)"$/, async (coords, value) => { - let cartesCoords = JSON.parse(coords); - await celOvSteps.verifyTMRawDataCellContents(cartesCoords, value); -}); - -When(/^scroll time machine raw data "(.*)"$/, async (d_coords) => { - let cartesCoords = JSON.parse(d_coords); - await celOvSteps.scrollTMRawDataTable(cartesCoords); -}); - -When(/^click time machine download CSV$/, async () => { - await celOvSteps.clickTMDownloadCSV(); -}); - -When(/^click the time machine script editor variables tab$/, async () => { - await celOvSteps.clickTMQEVariablesTab(); -}); - -Then(/^the time machine variables list contains$/, async varList => { - await celOvSteps.verifyTMQEVariablesList(varList); -}); - -Then(/^the time machine variables list does not contain$/, {timeout: 10000}, async varList => { - await celOvSteps.verifyTMQWVarieblesListAbsent(varList); -}); - -When(/^enter the value "(.*)" in the time machine variables filter$/, async value => { - await celOvSteps.enterTMQEVariableFilterValue(value); -}); - -When(/^clear the time machine variables filter$/, async () => { - await celOvSteps.clearTMQEVariablesFilter(); -}); - -When(/^hover over the time machine variable "(.*)"$/, async varname => { - await celOvSteps.hoverOverTMQEVariable(varname); -}); - -When(/^click the time machine variable "(.*)"$/, async varname => { - await celOvSteps.clickTMQEVariable(varname); -}); - -When(/^click inject the time machine variable "(.*)"$/, async varname => { - await celOvSteps.clickInjectTMQEVariable(varname); -}); - -Then(/^the time machine variable popover is not visible$/, async () => { - await celOvSteps.verifyTMQEVariablePopoverNotVisible(); -}); - -Then(/^the time machine variable popover is visible$/, async () => { - await celOvSteps.verifyTMQEVariablePopoverVisible(); -}); - -When(/^click time machine popover variable dropodown$/, async () => { - await celOvSteps.clickTMQEVariablePopoverVarDropdown(); -}); diff --git a/e2e/src/step_definitions/dashboards/dashboardStepDefs.js b/e2e/src/step_definitions/dashboards/dashboardStepDefs.js deleted file mode 100644 index 18e7f0ebb1..0000000000 --- a/e2e/src/step_definitions/dashboards/dashboardStepDefs.js +++ /dev/null @@ -1,339 +0,0 @@ -import { Then, When, Given } from 'cucumber'; -const dashboardSteps = require(__srcdir + '/steps/dashboards/dashboardSteps.js'); - -let dbdSteps = new dashboardSteps(__wdriver); - -When(/^name dashboard "(.*)"$/, async name => { - await dbdSteps.nameDashboard(name); -}); - -Then(/^the dashboard named "(.*)" is loaded$/, {timeout: 10000}, async name => { - await dbdSteps.verifyDashboardLoaded(name); -}); - -Then(/^the new dashboard page is loaded$/, {timeout: 10000}, async () => { - await dbdSteps.verifyDashboardLoaded('Name this Dashboard'); -}); - -Then(/^the dashboard contains a cell named "(.*)"$/, async name => { - await dbdSteps.verifyDashboardCellVisible(name); -}); - -Then(/^the empty dashboard contains a documentation link$/, async () => { - await dbdSteps.verifyDashboardEmptyDocLinkVisible(); - await dbdSteps.verifyDashboardEmptyDocLink('https://v2.docs.influxdata.com/v2.0/visualize-data/variables/'); -}); - -Then(/^the empty dashboard contains Add a Cell button$/, async () => { - await dbdSteps.verifyDashboardEmptyAddCell(); -}); - -When(/^click dashboard time locale dropdown$/, async () => { - await dbdSteps.clickDashboardTimeLocaleDropdown(); -}); - -Then(/^the active dashboard dropdown contains items:$/, async items => { - await dbdSteps.verifyDashboardDropdownContains(items); -}); - -When(/^click dashboard refresh dropdown$/, async () => { - await dbdSteps.clickDashboardRefreshDropdown(); -}); - -Then(/^the active dashboard dropdown contains dividers:$/, async labels => { - await dbdSteps.verifyDashboardDropdownContainsDividers(labels); -}); - -When(/^click dashboard time range dropdown$/, async () => { - await dbdSteps.clickDashboardTimeRangeDropdown(); -}); - -When(/^click the empty create cell button$/, async () => { - await dbdSteps.clickCreateCellEmpty(); -}); - -When(/^click the header add cell button$/, async () => { - await dbdSteps.clickHeaderAddCellButton(); -}); - -Then(/^there is no dashboard cell named "(.*)"$/, async name => { - await dbdSteps.verifyCellNotPresent(name); -}); - -Then(/^the cell named "(.*)" contains the empty graph message$/, async name => { - await dbdSteps.verifyEmptyGraphMessage(name); -}); - -Then(/^the cell named "(.*)" has no results$/, async name => { - await dbdSteps.verifyEmptyGraphNoResults(name); -}); - -Then(/^the cell named "(.*)" contains a graph error$/, async name => { - await dbdSteps.verifyCellContainsGraphError(name); -}); - -Then(/^the cell named "(.*)" contains a graph$/, async name => { - await dbdSteps.verifyCellContainsGraph(name); -}); - -When(/^get the current graph of the cell "(.*)"$/, async name => { - await dbdSteps.getCurrentGraphOfCell(name); -}); - -When(/^get metrics of cell named "(.*)"$/, async name => { - await dbdSteps.getCellMetrics(name); -}); - -When(/^toggle context menu of dashboard cell named "(.*)"$/, async name => { - await dbdSteps.toggleDashboardCellContextMenu(name); -}); - -When(/^toggle context menu of 2nd dashboard cell named "(.*)"$/, async name => { - await dbdSteps.toggle2ndDashboardCellContextMenu(name); -}); - -When(/^click cell content popover add note$/, async () => { - await dbdSteps.clickDashboardPopOverlayAddNote(); -}); - -Then(/^click note popup cancel$/, async () => { - await dbdSteps.clickNotePopupCance(); -}) - -When(/^click cell content popover edit note$/, async () => { - await dbdSteps.clickDashboardPopOverlayEditNote(); -}); - -When(/^click cell content popover configure$/, async () => { - await dbdSteps.clickDashboardPopOverlayConfigure(); -}); - -When(/^click cell content popover delete$/, async () => { - await dbdSteps.clickDashboardPopOverlayDelete(); -}); - -When(/^click cell content popover delet confirm$/, async () => { - await dbdSteps.clickDashboardPopOverlayDeleteConfirm(); -}); - -When(/^click cell edit content popover clone$/, async () => { - await dbdSteps.clickDashboardPopOverlayClone(); -}); - -Then(/^the edit note popup is loaded$/, async () => { - await dbdSteps.verifyEditNotePopupLoaded(); -}); - -When(/^enter the cell note popup CodeMirror text:$/, async text =>{ - await dbdSteps.setCellNotePopupCodeMirrorText(text); -}); - -Then(/^the cell note popup Markdown preview panel contains$/, async text=> { - await dbdSteps.verifyCellNotPopupPreviewContains(text); -}); - -When(/^click the cell note popup save button$/, async () => { - await dbdSteps.clickCellNotePopupSave(); -}); - -Then(/^the cell named "(.*)" has a note indicator$/, async name => { - await dbdSteps.verifyCellHasNoteIndicator(name); -}); - -When(/^click the note indicator of the "(.*)" cell$/, async name => { - await dbdSteps.clickCellNoteIndicator(name); -}); - -Then(/^the cell note popover contains:$/, async text => { - await dbdSteps.verifyContentsOfCellNote(text); -}); - -When(/^click the cell title "(.*)"$/, async name => { - await dbdSteps.clickCellTitle(name); -}); - -Then(/^the cell note popover is not loaded$/, async () => { - await dbdSteps.verifyCellNotePopoverNotPresent(); -}); - -Then(/^the cell content popover has item edit note$/, async () => { - await dbdSteps.verifyCellContentPopoverItemEditNote(); -}); - -Then(/^the cell content popover is not loaded$/, async () => { - await dbdSteps.verifyCellContentPopoverNotPresent(); -}); - -Then(/^the cell note popup Code Mirror text contains:$/, async text => { - await dbdSteps.verifyCodeMirrorContainsText(text); -}); - -When(/^clear the cell note popup Code Mirror text$/, async () => { - await dbdSteps.clearCellNotePopupCodeMirror(); -}); - -Then(/^the cell note popup markup preview panel has no text$/, async () => { - await dbdSteps.verifyCellNotePopupMarkupPreviewNoText(); -}); - -When(/^move the cell named "(.*)" by "(.*)"$/, {timeout: 15000}, async (name, vector) => { - let deltaCoords = JSON.parse(vector); - await dbdSteps.moveDashboardCell(name, deltaCoords); -}); - -When(/^resize the cell name "(.*)" by "(.*)"$/, {timeout: 15000}, async (name, vector) => { - let deltaSize = JSON.parse(vector); - await dbdSteps.resizeDashboardCell(name, deltaSize); -}); - -Then(/^size of the cell named "(.*)" has changed by "(.*)"$/, async (name, change) => { - let deltaSize = JSON.parse(change); - await dbdSteps.verifyDashboardCellSizeChange(name, deltaSize); - -}); - -Then(/^the size of the of the cell named "(.*)" is unchangd$/, async name => { - await dbdSteps.verifyDashboardCellSizeChange(name, {dw: 0, dh: 0}); -}); - -Then(/^the location of the cell named "(.*)" is changed by "(.*)"$/, async (name, vector) => { - let deltaCoords = JSON.parse(vector); - await dbdSteps.verifyCellPositionChange(name, deltaCoords); -}); - -Then(/^the location of the cell named "(.*)" is unchanged$/, async name => { - await dbdSteps.verifyCellPositionChange(name, {dx: 0, dy: 0}); -}); - -When(/^click the dashboard Time Range Dropdown$/, async () => { - await dbdSteps.clickDashboardTimeRangeDropdown(); -}); - -Then(/^the dashboard Time Range Dropdown selected contains "(.*)"$/, async value => { - await dbdSteps.verifyDashboardTimeRangeDropdownSelected(value); -}); - -When(/^select dashboard Time Range "(.*)"$/, async item => { - await dbdSteps.selectDashboardTimeRange(item); -}); - -Then(/^the graph of the cell "(.*)" has changed$/, async name => { - await dbdSteps.verifyCellGraphChange(name); -}); - -Then(/^the graph of the cell "(.*)" has not changed$/, async name => { - await dbdSteps.verifyCellGraphNoChange(name); -}); - -Then(/^the graph of the cell "(.*)" is visible$/, async name => { - await dbdSteps.verifyCellGraphVisible(name); -}); - -Then(/^the graph of the cell "(.*)" differs from "(.*)"$/, async (name1, name2) => { - await dbdSteps.compareCellGraphs(name1, name2, false); -}); - -When(/^hover over the graph of the cell named "(.*)"$/, async name => { - await dbdSteps.hoverGraphOfCell(name); -}); - -Then(/^the cell graph data point infobox is visible$/, async () => { - await dbdSteps.verifyCellGraphDataPointInfoBox(); -}); - -When(/^move horizontally to "(.*)" of graph cell named "(.*)"$/, async (fraction,name) => { - await dbdSteps.moveToHorizontalFractionOfGraphCell(fraction, name); -}); - -When(/^drag horizontally to "(.*)" of graph cell named "(.*)"$/, async (fraction, name) => { - await dbdSteps.dragToHorizontalFractionOfGraphCell(fraction, name); -}); - -When(/^move vertically to "(.*)" of graph cell named "(.*)"$/, async (fraction, name) => { - await dbdSteps.moveToVerticalFractionOfGraphCell(fraction, name); -}); - -When(/^drag vertically to "(.*)" of graph cell named "(.*)"$/, async (fraction, name) => { - await dbdSteps.dragToVerticalFractionOfGraphCell(fraction, name); -}); - -When(/^Click at the point "(.*)" of graph cell named "(.*)"$/, async (target, name) => { - let fracs = JSON.parse(target); - await dbdSteps.clickPointWithinCellByFractions(fracs, name); -}); - -Then(/^the cell named "(.*)" is visible in the dashboard$/, async name => { - await dbdSteps.verifyDashboardCellVisible(name); -}); - -Then(/^there is a second dashboard cell named "(.*)"$/, async name => { - await dbdSteps.verifyCountCellsNamed(name, 2); -}); - -Then(/^the cell named "(.*)" is no longer present$/, async name => { - await dbdSteps.verifyCellNotPresent(name); -}); - -When(/^hover over the error icon of the cell "(.*)"$/, async name => { - await dbdSteps.hoverOverCellErrorIcon(name); -}); - -Then(/^the empty cell error popover message is:$/, async msg => { - await dbdSteps.verifyEmptyCellErrorPopoverMessage(msg); -}); - -Then(/^the cell error message of the cell named "(.*)" is:$/, async (name, msg) => { - await dbdSteps.verifyCellErrorMessage(name, msg); -}); - -Then(/^the dashboard variables button is highlighted$/, async () => { - await dbdSteps.verifyVariablesButtonActive(); -}); - -Then(/^the dashboard variables button is not highlighted$/, async () => { - await dbdSteps.verifyVariablesButtonInactive(); -}); - -When(/^click the value dropdown button for variable "(.*)"$/, async varname => { - await dbdSteps.clickValueDropdownOfVar(varname); -}); - -Then(/^the value dropdown for variable "(.*)" contains$/, async (varname,items) =>{ - await dbdSteps.verifyVariableDropdownContents(varname,items) -}); - -Then(/^the selected item of the dropdown for variable "(.*)" is "(.*)"$/, async (varname, item) => { - await dbdSteps.verifySlectedValueOfVariable(varname, item); -}); - -When(/^click the item "(.*)" for variable "(.*)"$/, async (item, varname) => { - await dbdSteps.clickItemOfVariableValueDropdown(item, varname); -}); - -Then(/^the value dropdown for variable "(.*)" is visible$/, async varname => { - await dbdSteps.verifyVariableValuesDropdownVisible(varname); -}); - -Then(/^the value dropdown for variable "(.*)" is not visible$/, async varname => { - await dbdSteps.verifyVariableValuesDropdownNotVisible(varname); -}); - -When(/^click the dashboard variables button$/, async() => { - await dbdSteps.clickVariablesButton(); -}); - -When(/^click dashboard add note button$/, async () => { - await dbdSteps.clickDashboardMainAddNote(); -}); - -Then(/^main "(.*)" note popup is loaded$/, async state => { - await dbdSteps.verifyMainEditNotePopupLoaded(state); -}); - -Then(/^the main note popup markdown preview panel contains a "(.*)" tag with "(.*)"$/, async (tag,content) => { - await dbdSteps.verifyNotePopupMarkdownPreviewContains(tag, content); -}); - -Then(/^the note cell contains a "(.*)" tag with "(.*)"$/, async (tag,content) => { - await dbdSteps.verifyNoteCellContains(tag,content); -}); diff --git a/e2e/src/step_definitions/dashboards/dashboardsStepDefs.js b/e2e/src/step_definitions/dashboards/dashboardsStepDefs.js deleted file mode 100644 index 860555f4ee..0000000000 --- a/e2e/src/step_definitions/dashboards/dashboardsStepDefs.js +++ /dev/null @@ -1,288 +0,0 @@ -import { Then, When } from 'cucumber'; -const dashboardsSteps = require(__srcdir + '/steps/dashboards/dashboardsSteps.js'); - -let dbdsSteps = new dashboardsSteps(__wdriver); - -Then(/^the Dashboards page is loaded$/, {timeout: 2 * 5000}, async() => { - await dbdsSteps.isLoaded(); - await dbdsSteps.verifyIsLoaded(); - await dbdsSteps.verifyHeaderContains('Dashboards'); -}); - -When(/^click create dashboard control$/, async() => { - await dbdsSteps.clickCreateDashboard(); -}); - -When(/^click "(.*)" in create dashboard dropdown$/, async item => { - await dbdsSteps.clickCreateDashboardItem(item); -}); - -When(/^click the empty Create dashboard dropdown button$/, async () => { - await dbdsSteps.clickCreateDashboardEmpty(); -}); - -Then(/^the empty create dashboard dropdown list contains$/, async (items) => { - await dbdsSteps.verifyEmptyCreateDashboardItems(items); -}); - -When(/^click the create dashboard item "(.*)"$/, async (item) => { - await dbdsSteps.clickCreateDashboardItem(item); -}); - -Then(/^the empty Create dashboard dropdown button is not present$/, async () => { - await dbdsSteps.verifyEmptyCreateDashboardNotPresent(); -}); - -Then(/^there is a dashboard card named "(.*)"$/, async name =>{ - await dbdsSteps.verifyDashboardCardVisible(name); -}); - -Then(/^there is no dashboard card named "(.*)"$/, async name => { - await dbdsSteps.verifyDashboardCardNotPresent(name); -}); - - -When(/^hover over dashboard card named "(.*)"$/, async name => { - await dbdsSteps.hoverOVerDashboardCard(name); -}); - -Then(/^the export button for the dashboard card "(.*)" is visible$/, async name => { - await dbdsSteps.verifyExportButtonOfCardVisible(name); -}); - -Then(/^the clone button for the dashboard card "(.*)" is visible$/, async name => { - await dbdsSteps.verifyCloneButtonOfCardVisible(name); -}); - -Then(/^the delete button for the dashboard card "(.*)" is visible$/, async name => { - await dbdsSteps.verifyDeleteButtonOfCardVisible(name); -}); - -When(/^hover over dashboard card name "(.*)"$/, async name => { - await dbdsSteps.hoverOverDashboardCardName(name); -}); - -When(/^click the edit dashboard card name button for "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardNameButton(name); -}); - -When(/^clear the name input of the dashboard card "(.*)"$/, async name => { - await dbdsSteps.clearDashboardCardName(name); -}); - -When(/^enter the new name "(.*)" in the name input of the dashboard card "(.*)"$/, async (newName, oldName) => { - await dbdsSteps.renameDashboardCard(newName, oldName); -}); - -Then(/^the description for card "(.*)" contains "(.*)"$/, async (name, descr) => { - await dbdsSteps.verifyDashboardCardContainsDescription(name,descr); -}); - -When(/^hover over description of the dashboard card "(.*)"$/, async name => { - await dbdsSteps.hoverOverDashboardCardDescription(name); -}); - -When(/^click the edit description button for the dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardEditDescriptionButton(name); -}); - -When(/^enter into the dashboard card "(.*)" the description:$/, async (name, descr) => { - await dbdsSteps.enterDashboardCardDescription(name,descr); -}); - -When(/^click empty label for the dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickEmptyLabelOfDashboardCard(name); -}); - -When(/^click add label for the dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickAddLabelOfDashboardCard(name); -}); - -Then(/^the label "(.*)" in the popover selector is visible$/, async label => { - await dbdsSteps.verifyLabelInDashboardsPopoverIsVisible(label); -}); - -When(/^enter "(.*)" in the popover label selector filter$/, async text => { - await dbdsSteps.enterDashboardLabelsFilter(text); -}); - -Then(/^there are "(.*)" label pills in the select label popover$/, async count => { - await dbdsSteps.verifyDashboardAddLabelsPillCount(count); -}); - -Then(/^the create new label item is not visible in the popover$/, async () => { - await dbdsSteps.verifyLabelPopoverCreateNewNotPresent(); -}); - -Then(/^the create new label item is visible in the popover$/, async () => { - await dbdsSteps.verifyLabelPopoverCreateNewIsVisible(); -}); - -When(/^click the new label item in the add labels popover$/, async () => { - await dbdsSteps.clickLabelPopoverCreateNewLabel(); -}); - -Then(/^the dashboard card "(.*)" has the label "(.*)"$/, async (name, label) => { - await dbdsSteps.verifyDashboardCardHasLabel(name, label); -}); - -When(/^click the add label button for the dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardAddLabel(name); -}); - -When(/^hover over the label "(.*)" of the dashboard card "(.*)"$/, async (label,name) => { - await dbdsSteps.hoverDashboardCardLabel(name, label); -}); - -When(/^click remove label "(.*)" from the dashboard card "(.*)"$/, async (label,name) => { - await dbdsSteps.clickDashboardCardRemoveLabel(name,label); -}); - -Then(/^the dashboard card "(.*)" labels empty message is visible$/, async name => { - await dbdsSteps.verifyDashboardCardLabelsEmptyVisible(name); -}); - -Then(/^the label "(.*)" of the dashboard card "(.*)" is not present$/, async (label,name) => { - await dbdsSteps.verifyDashboardCardLabelNotPresent(name, label); -}); - -Then(/^the label "(.*)" is not present in the popover selector$/, async label => { - await dbdsSteps.verifyLabelInDashboardsPopoverIsNotPresent(label); -}); - -Then(/^the dashboards page contains the cards:$/, async cards => { - await dbdsSteps.verifyDashboardCardsVisible(cards); -}); - -When(/^enter the term "(.*)" in the dashboards filter$/, async term => { - await dbdsSteps.enterDashboardsCardFilter(term); -}); - -When(/^clear the dashboards filter$/, async () => { - await dbdsSteps.clearDashboardsCardFilter(); -}); - -Then(/^the dashboards page does not contain the cards:$/, {timeout: 15000}, async cards => { - await dbdsSteps.verifyDashboardCardsNotPresent(cards); -}); - -Then(/^the Import Dashboard popup is loaded$/, async () => { - await dbdsSteps.verifyImportDashboardPopupVisible(); -}); - -Then(/^the Create Dashboard from Template popup is loaded$/, async () => { - await dbdsSteps.verifyCreateDashboardFromTemplatePopupVisible(); -}); - -When(/^upload the import dashboard file "(.*)"$/, async path2file => { - await dbdsSteps.uploadImportDashboardPopupFile(path2file); -}); - -Then(/^the import dashboard drag and drop header contains success "(.*)"$/, async path2file => { - await dbdsSteps.verifyImportPopupUploadSuccess(); - await dbdsSteps.verifyImportPopupUploadFilename(path2file); -}); - -When(/^click the Import Dashboard button$/, async () => { - await dbdsSteps.clickImportDashboardButton(); -}); - -When(/^click the Import Dashboard popup radio button Paste Json$/, async () => { - await dbdsSteps.clickImportDashboardPasteJSON(); -}); - -Then(/^the Import Dashboard file upload control is not present$/, async () => { - await dbdsSteps.verifyImportDashboardFileUploadNotPresent(); -}); - -When(/^paste contents of file "(.*)" into the JSON textarea$/, {timeout: 90000}, async filepath => { - await dbdsSteps.pasteFileContentsImportDashboardTextarea(filepath); -}); - -When(/^click Dashboard from Template popup cancel button$/, async () => { - await dbdsSteps.clickFromTemplatePopupCancel(); -}); - -When(/^click the template item "(.*)"$/, async item => { - await dbdsSteps.clickFromTemplatePopupTemplateItem(item, async () => { - await this.driver.sleep(1000); //slow to load? - }); -}); - -Then(/^the template preview cell "(.*)" is visible$/, async name => { - await dbdsSteps.verifyFromTemplatePreviewCellVisible(name); -}); - -Then(/^the Dashboard from Template create button is disabled$/, async () => { - await dbdsSteps.verifyFromTemplatePopupCreateDisabled(); -}); - -When(/^click Dashboard from Template create button$/, async () => { - await dbdsSteps.clickDashboardFromTemplateCreate(); -}); - -Then(/^the dashboards are sorted as:$/, async dBoards => { - await dbdsSteps.verifyDashboardSortOrder(dBoards); -}); - -When(/^click dashboards sort type dropdown$/, async () => { - await dbdsSteps.clickSortDashboardsByType(); -}); - -When(/^click dashboards sort by "(.*)"$/, async item => { - await dbdsSteps.clickSortDashboardsListItem(item); -}); - -When(/^click delete of dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardDelete(name); -}); - -When(/^click delete confirm of dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardDeleteConfirm(name); -}); - -When(/^click clone of the dashboard card named "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardClone(name); -}); - -When(/^click the clone confirm of dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardCloneConfirm(name); -}); - -When(/^click export of the dashboard card named "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardExport(name); -}); - -When(/^click confirm export of the dashboard card "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardExportConfirm(name); -}); - -Then(/^the Export Dashboard popup is loaded$/, async () => { - await dbdsSteps.verifyExportDashboardPopupLoaded(); -}); - -When(/^click the Export Dashboard dismiss button$/, async () => { - await dbdsSteps.clickExportDashboardPopupDismiss(); -}); - -When(/^click Export Dashboard popup Download JSON for "(.*)"$/, {timeout: 60000}, async filePath => { - await dbdsSteps.clickExportDashboardDownloadJSON(filePath); -}); - -When(/^click Export Dashboard popup Save as Template$/, async () => { - await dbdsSteps.clickExportDashboardSaveAsTemplate(); -}); - -When(/^click Export Dashboard popup Copy to Clipboard$/, async () => { - await dbdsSteps.clickExportDashboardCopyToClipboard(); -}); - -When(/^click the dashboard name "(.*)"$/, async name => { - await dbdsSteps.clickDashboardCardName(name); -}); - -When(/^click the dashboards filter input$/, async () => { - await dbdsSteps.clickDashboardsFilterInput(); -}); - - diff --git a/e2e/src/step_definitions/dataExplorer/dataExplorerStepDefs.js b/e2e/src/step_definitions/dataExplorer/dataExplorerStepDefs.js deleted file mode 100644 index 47089c9fc5..0000000000 --- a/e2e/src/step_definitions/dataExplorer/dataExplorerStepDefs.js +++ /dev/null @@ -1,204 +0,0 @@ -import {Then, When} from 'cucumber'; -const dataExplorerSteps = require(__srcdir + '/steps/dataExplorer/dataExplorerSteps.js'); - -let deSteps = new dataExplorerSteps(__wdriver); - -Then(/^the Data Explorer page is loaded$/, {timeout: 2 * 5000}, async () => { - await deSteps.isLoaded(); - await deSteps.verifyIsLoaded(); - //await deSteps.verifyHeaderContains('Data Explorer'); -}); - -When(/^choose bucket named "(.*)"$/, async (bucket) => { - await deSteps.chooseBucket(bucket); -}); - -When(/^choose the item "(.*)" in builder card "(.*)"$/, async (measurement,index) => { - await deSteps.chooseItemFromBuilderCard(measurement, index); -}) - -When(/^click the submit button$/, async () => { - await deSteps.clickQuerySubmitButton(); -}); - -Then(/^the time machine graph is shown$/, async() => { - await deSteps.verifyGraphVisible(); -}); - -When(/^hover over the graph$/, async() => { - await deSteps.hoverOverGraph(); -}); - -Then(/^the graph data point infobox is visible$/, async () => { - await deSteps.verifyGraphDataPointInfoBox(); -}); - -When(/^get the current graph$/, async() => { - await deSteps.getCurrentGraph(); -}); - -When(/^move horizontally to "(.*)" of the graph$/, async (fraction) => { - await deSteps.moveToHorizontalFractionOfGraph(fraction); -}); - -When(/^drag horizontally to "(.*)" of the graph$/, async (fraction) => { - await deSteps.dragToHorizontalFractionOfGraph(fraction); -}); - -Then(/^the graph has changed$/, async() => { - await deSteps.verifyGraphChange(); -}); - - -When(/^Click at the point "(.*)" of the graph$/, async (target) => { - let fracs = JSON.parse(target); - await deSteps.clickPointWithinGraphByFractions(fracs); -}); - -When(/^move vertically to "(.*)" of the graph$/, async (fraction) => { - await deSteps.moveToVerticalFractionOfGraph(fraction); -}); - -When(/^drag vertically to "(.*)" of the graph$/, async (fraction) => { - await deSteps.dragToVerticalFractionOfGraph(fraction); -}); - -When(/^click the refresh button$/, async () => { - await deSteps.clickQuerySubmitButton(); -}); - -When(/^click the automatic refresh - paused$/, async () => { - await deSteps.clickRefreshDropdownPaused(); -}); - -When(/^click the automatic refresh - active$/, async () => { - await deSteps.clickRefreshDropdownActive(); -}); - -When(/^select the automatic refresh "(.*)"$/, async (item) => { - await deSteps.selectRefreshDropdownItem(item); -}); - -When(/^click the time machine add query button$/, async () => { - await deSteps.clickAddQueryButton(); -}); - -When(/^right click on the time machine query tab named "(.*)"$/, async (title) => { - await deSteps.rightClickQueryTabTitle(title); -}); - -When(/^click on the time machine query tab named "(.*)"$/, async (title) => { - await deSteps.clickQueryTabTitle(title); -}); - -When(/^click on "(.*)" in the query tab menu$/, async (item) => { - await deSteps.selectQueryTabMenuItem(item); -}); - -When(/^input a new query tab name as "(.*)"$/, async (name) => { - await deSteps.setQueryTabName(name); -}); - -When(/^click the Script Editor button$/, async () => { - await deSteps.clickScriptEditorButton(); -}); - -When(/^paste into Script Editor text area$/, { timeout: 20000 }, async text => { - await deSteps.pasteIntoScriptEditor(text); -}); - -When(/^click the graph view type dropdown$/, async () => { - await deSteps.clickViewTypeDropdown(); -}); - -When(/^select the graph view type "(.*)"$/, async (type) => { - await deSteps.selectViewType(type); -}); - -Then(/^the graph view type is Graph plus Single Stat$/, async () => { - await deSteps.verifySingleStatTextVisible(); -}); - -When(/^click the view raw data toggle$/, async () => { - await deSteps.clickViewRawDataToggle(); -}); - -Then(/^the raw data table is visible$/, async () => { - await deSteps.verifyRawDataTableVisible(); -}); - -When(/^click the graph time range dropdown$/, async () => { - await deSteps.clickTimeRangeDropdown(); -}); - -When(/^select the graph time range "(.*)"$/, async (item) => { - await deSteps.selectTimeRangeDropdownItem(item); -}); - -When(/^search for function "(.*)"$/, async (funct) => { - await deSteps.searchFunction(funct); -}); - -When(/^select the function "(.*)"$/, async (funct) => { - await deSteps.selectFunctionFromList(funct); -}); - -When(/^click on the Save as button$/, async () => { - await deSteps.clickSaveAsButton(); -}); - -Then(/^the Save as overlay is visible$/, async () => { - await deSteps.verifySaveAsOverlayVisible(); -}); - -When(/^click the Target Dashboard dropdown$/, async () => { - await deSteps.clickTargetDashboardDropdown(); -}); - -When(/^select Create a New Dashboard from the Target Dashboard dropdown$/, async () => { - await deSteps.selectTargetDashboardDropdownItem(); -}); - -When(/^input the New Dashboard Name "(.*)"$/, async (name) => { - await deSteps.setNewDashboardName(name); -}); - -When(/^input the Cell Name "(.*)"$/, async (name) => { - await deSteps.setCellName(name); -}); - -When(/^click on the Save as Dashboard Cell button$/, async () => { - await deSteps.clickSaveAsDashboardCellButton(); -}); - -When(/^click on tab "(.*?)" in the Save As popup$/, async(tab) => { - await deSteps.clickSaveAsPopupTab(tab); -}); - -When(/^input the Task Name "(.*)"$/, async (name) => { - await deSteps.setTaskName(name); -}); - -When(/^input the Task Interval "(.*)"$/, async (interval) => { - await deSteps.setTaskInterval(interval); -}); - -When(/^input the Task Offset "(.*)"$/, async (offset) => { - await deSteps.setTaskOffset(offset); -}); - -When(/^click on the Save as Task button$/, async () => { - await deSteps.clickSaveAsTaskButton(); -}); - -When(/^input the variable name "(.*)"$/, async (name) => { - await deSteps.setVariableName(name); -}); - -When(/^click on the Save as Variable button$/, async () => { - await deSteps.clickSaveAsVariableButton(); -}); - - - - diff --git a/e2e/src/step_definitions/home/homeStepDefs.js b/e2e/src/step_definitions/home/homeStepDefs.js deleted file mode 100644 index 0d244f9b3c..0000000000 --- a/e2e/src/step_definitions/home/homeStepDefs.js +++ /dev/null @@ -1,35 +0,0 @@ -import { Then, When } from 'cucumber'; -const homeSteps = require(__srcdir + '/steps/home/homeSteps.js'); - -let hSteps = new homeSteps(__wdriver); - -Then(/^the home page is loaded$/, {timeout: 2 * 5000}, async () => { - await hSteps.isLoaded(); - await hSteps.verifyIsLoaded(); -}); - -When(/^click logout from the home page$/, async() => { - await hSteps.clickLogout(); -}); - -When(/^I click the panel "(.*)"$/, async title => { - await hSteps.clickQuickStartPanel(title); -}); - -Then(/^the dashboards panel contains a link to "(.*)"$/, async dbdName => { - await hSteps.verifyDbdPanelDashboard(dbdName); -}); - -When(/^click the dashboard link to "(.*)"$/, async dbdName => { - - await hSteps.clickDbdPanelDashboard(dbdName); - -}); - -Then(/^the dashboards panel contains links:$/, async links => { - await hSteps.verifyDashboardLinksInPanel(links); -}); - -When(/^click the dashboards panel link "(.*)"$/, async link => { - await hSteps.clickDashboardLinkFromPanel(link); -}); diff --git a/e2e/src/step_definitions/influx/influxStepDefs.js b/e2e/src/step_definitions/influx/influxStepDefs.js deleted file mode 100644 index 4e90e927fb..0000000000 --- a/e2e/src/step_definitions/influx/influxStepDefs.js +++ /dev/null @@ -1,62 +0,0 @@ -import { Then, When } from 'cucumber'; -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const createOrgSteps = require(__srcdir + '/steps/createOrgSteps.js'); - -let iSteps = new influxSteps(__wdriver); -let cOrgSteps = new createOrgSteps(__wdriver); - -Then(/^influx page is loaded$/, async() => { - - await iSteps.verifyIsLoaded(); - -}); - -Then(/^the header contains the org name "(.*?)"$/, async (orgname) => { - await iSteps.verifyHeaderContains((orgname === 'DEFAULT') ? __defaultUser.org : orgname); -}); - -Then(/^the home page header contains "(.*)"$/, async content => { - await iSteps.verifyHeaderContains(content); -}); - -Then(/^the Create Organization form is loaded$/, {timeout: 2 * 5000}, async () => { - await cOrgSteps.isLoaded(); - await cOrgSteps.verifyIsLoaded(); -}); - -When(/^hover over the "(.*?)" menu item$/, async (item) => { - await iSteps.hoverNavMenu(item); -}); - -Then(/^the home submenu items are "(.*?)"$/, async(state) => { - await iSteps.verifySubMenuItems('home:heading', state); - await iSteps.verifySubMenuItems('home:neworg', state); - await iSteps.verifySubMenuItems('home:logout', state); -}); - -When(/^click nav sub menu "(.*?)"$/, async(item) => { - await iSteps.clickSubMenuItem(item); -}); - -When(/^click user nav item "(.*)"$/, async (item) => { - await iSteps.clickUserMenuItem(item); -}); - -When(/^click nav menu item "(.*?)"$/, async(item) => { - await iSteps.clickMenuItem(item); -}); - - -Then(/^the menu item text "(.*?)" is "(.*?)"$/, async (text, state) => { - await iSteps.verifyVisibilityNavItemByText(text, state.toLowerCase() !== 'hidden'); -}); - -Then(/^the feedback URL should include "(.*?)"$/, async text => { - await iSteps.verifyFeedbackLinkContains(text); -}); - -Then(/^the user menu items are "(.*?)"$/, async(state) => { - await iSteps.verifyUserMenuItems('switchOrg', state); - await iSteps.verifyUserMenuItems('createOrg', state); - await iSteps.verifyUserMenuItems('logout', state); -}); diff --git a/e2e/src/step_definitions/loadData/bucketsStepDefs.js b/e2e/src/step_definitions/loadData/bucketsStepDefs.js deleted file mode 100644 index a1da38c789..0000000000 --- a/e2e/src/step_definitions/loadData/bucketsStepDefs.js +++ /dev/null @@ -1,316 +0,0 @@ -import { Given, Then, When } from 'cucumber'; -const bucketsSteps = require(__srcdir + '/steps/loadData/bucketsSteps.js'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -let bktTabSteps = new bucketsSteps(__wdriver); - -Then(/^the buckets are sorted as "(.*)"$/, async (bucketNames) => { - await bktTabSteps.verifyOrderByName(bucketNames); -}); - -Then(/^the bucket "(.*)" is not in the list$/, async (name) => { - await bktTabSteps.verifyBucketNotListedByName(name); -}); - -When(/^click the Create Bucket button$/, async () => { - await bktTabSteps.clickCreateBucket(); -}); - -Then(/^the Create Bucket Popup is loaded$/, async () => { - await bktTabSteps.verifyCreateBucketPopup(); -}); - -Then(/^the Create button of Create Bucket Popup is disabled$/, async () => { - await bktTabSteps.verifyCreateBucketCreateButtonEnabled(false); -}); - -Then(/^the Create button of Create Bucket Popup is enabled$/, async () => { - await bktTabSteps.verifyCreateBucketCreateButtonEnabled(true); -}); - -Then(/^the Retention Policy radio button "(.*)" is active$/, async (rp) => { - await bktTabSteps.verifyActiveRetentionPolicyButton(rp); -}); - -Then(/^the Retention Policy radio button "(.*)" is inactive$/, async (rp) => { - await bktTabSteps.verifyInactiveRetentionPolicyButton(rp); -}); - - -//Waiting for dismissal can take a few secs -When(/^dismiss the Create Bucket Popup$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.dismissBucketPopup(); -}); - -When(/^dismiss the Edit Bucket Popup$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.dismissBucketPopup(); -}); - -// Should be not present - removed from DOM -Then(/^the Create Bucket Popup is not present$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.verifyCreateBucketPopupNotPresent(); -}); - -Then(/^the Edit Bucket Popup is not present$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.verifyCreateBucketPopupNotPresent(); -}); - -//Waiting for dismissal can take a few secs -When(/^cancel the Create Bucket Popup$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.cancelBucketPopup(); -}); - -When(/^cancel the Edit Bucket Popup$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.cancelBucketPopup(); -}); - -Then(/^the Retention Policy intervals controls are not present$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.verifyRPIntervalControlsNotPresent(); -}); - -Then(/^the Retention Policy intervals controls are present$/, async () => { - await bktTabSteps.verifyRPIntervalControlsPresent(); -}); - -When(/^click the Retention Policy "(.*)" button$/, async(rp) => { - await bktTabSteps.clickRetentionPolicyButton(rp); -}); - -When(/^input the name of the bucket as "(.*)"$/, async (name) => { - await bktTabSteps.setBucketName(name); -}); - -When(/^clear all Retention Policy interval controls$/, async () => { - await bktTabSteps.clearAllRetentionPolicyIntervals(); -}); - -When(/^enter "(.*)" into the Retention Policy "(.*)" control$/, async(amount, unit) => { - await bktTabSteps.enterIntervalValue(amount, unit); -}); - -Then(/^the Retention Policy "(.*)" control contains the value "(.*)"$/, async(unit, value) => { - await bktTabSteps.verifyIntervalValue(value, unit); -}); - - -When(/^set the retention policy of the bucket as "(.*)"$/, async (rp) => { - - if(rp.toLowerCase() === 'never'){ - await bktTabSteps.clickRetentionPolicyButton('never'); - }else{ - //rp = rp.trim(); - //let policy = rp.split(" "); - await bktTabSteps.clickRetentionPolicyButton('intervals'); - await bktTabSteps.clickPopupRPDurationSelectorButton(); - await bktTabSteps.clickRPSelectorValue(rp); - //await bktTabSteps.enterIntervalValue(policy[0], policy[1]); - } -}); - -When(/^click the Create Bucket popup Create button$/, async () => { - await bktTabSteps.clickCreatePopupCreate(); -}); - -Then(/^the Retention Policy warning message contains "(.*)"$/, async (msg) => { - await bktTabSteps.verifyFormErrorMessageContains(msg); -}); - -Then(/^the Retention Policy warning message has disappeared$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.verifyFormErrorMessageNotPresent(); -}); - -Then(/^the bucket named "(.*)" is in the list$/, async (name) => { - await bktTabSteps.verifyBucketInListByName(name); -}); - -Then(/^the bucket card named "(.*)" is not in the list$/, async (name) => { - await bktTabSteps.verifyBucktNotInListByName(name); -}); - - -Then(/^the bucket named "(.*)" has a Retention Policy of "(.*)"$/, async (name, rp) => { - await bktTabSteps.verifyBucketHasRetentionPolicy(name, rp); -}); - -When(/^click on the bucket named "(.*)"$/, async (name) => { - await bktTabSteps.clickOnBucketNamed(name); -}); - -When(/^click on settings for bucket named "(.*)"$/, async (name) => { - await bktTabSteps.clickOnBucketSettings(name); -}); - -Then(/^the Edit Bucket popup is loaded$/, async () => { - await bktTabSteps.verifyEditBucketPopup(); -}); - -Then(/^the name edit textbox of the Edit Bucket popup is disabled$/, async() => { - await bktTabSteps.verifyNameInputEnabled(false); -}); - -Then(/^the form help text contains "(.*)"$/, async (text) => { - await bktTabSteps.verifyPopupHelpText(text); -}); - -When(/^click Edit Bucket Popup Save Changes$/, async () => { - await bktTabSteps.clickSaveChanges(); -}); - -When(/^enter "(.*)" in the Buckets filter field$/, {timeout: 10000}, async (text) => { - await bktTabSteps.setFilterValue(text); -}); - -When(/^clear the Buckets filter field$/, async () => { - await bktTabSteps.clearFilterValue(); -}); - -Given(/^ensure buckets name sort order "(.*)"$/,{timeout: 2 * 5000}, async (order) => { - await bktTabSteps.ensureNameSortOrder(order); -}); - -When(/^click buckets sort by retention policy$/, async () => { - await bktTabSteps.clickRetentionSort(); -}); - -When(/^click the buckets page title$/, async () => { - await bktTabSteps.clickPageTitle(); -}); - -//need to move focus from list sometimes -When(/^click buckets filter$/, async () => { - await bktTabSteps.clickBucketsFilter(); -}); - -When(/^hover over bucket card named "(.*)"$/,{timeout: 2 * 5000}, async (name) => { - await bktTabSteps.hoverOverCardNamed((name === 'DEFAULT') ? __defaultUser.bucket : name); - await bktTabSteps.driver.sleep(5000); -}); - -Then(/^the delete button of the card named "(.*)" is not present$/, {timeout: 2 * 5000}, async (name) => { - await bktTabSteps.verifyBucketCardDeleteNotPresent(name); -}); - -When(/^click the delete button of the card named "(.*)"$/, {timeout: 10000}, async (name) => { - await bktTabSteps.clickBucketCardDelete(name); -}); - -When(/^click the confirm delete button of the card named "(.*)"$/, async (name) => { - await bktTabSteps.clickBucketCardDeleteConfirm(name); -}); - -When(/^click add data button for bucket "(.*)"$/, async (name) => { - await bktTabSteps.clickAddDataButtonOfCard((name === 'DEFAULT') ? __defaultUser.bucket : name); -}); - -Then(/^the add data popover for the bucket "(.*)" is not visible$/, async (name) => { - await bktTabSteps.verifyBucketCardPopoverVisible((name === 'DEFAULT') ? __defaultUser.bucket : name, false); -}); - -Then(/^the add data popover is not present$/, async () => { - await bktTabSteps.verifyBucketCardPopover(false); -}); - - -Then(/^the add data popover for the bucket "(.*)" is visible$/, async (name) => { - await bktTabSteps.verifyBucketCardPopoverVisible((name === 'DEFAULT') ? __defaultUser.bucket : name, true); -}); - -When(/^click the popover item "(.*)" for the bucket "(.*)"$/, async (item, name) => { - await bktTabSteps.clickPopoverItemForBucketCard((name === 'DEFAULT') ? __defaultUser.bucket : name, item); -}); - -When(/^click bucket card popover item "(.*)"$/, async item => { - await bktTabSteps.clickPopoverItem(item); -}); - -Then(/^the first page of the Line Protocol Wizard is loaded$/, async () => { - await bktTabSteps.verifyLineProtocolWizardVisible(true); -}); - -When(/^click radio button "(.*)"$/, async (name) => { - await bktTabSteps.clickRadioButton(name); -}); - -Then(/^the data point text area is visible$/, async () => { - await bktTabSteps.verifyDataPointsTextAreaVisible(true); -}); - -When(/^enter "(.*)" datapoints with value named "(.*)" starting at "(.*)" with "(.*)" data of type "(.*)" and prec "(.*)"$/, - async (count, value, start, mode, type, prec) => { - await bktTabSteps.enterLineProtocolDataPoints(count, value, start, mode, type, prec); - await bktTabSteps.driver.sleep(3000); - }); - - -When(/^enter "(.*)" into the line protocol text area$/, async data => { - await bktTabSteps.enterLineProtocolRawData(data); -}); - -When(/^click the Line Protocol wizard precision dropdown$/, async () => { - await bktTabSteps.clickLineProtocolPrecisionDropdown(); -}); - -When(/^click the Line Protocol wizard continue button$/, async () => { - await bktTabSteps.clickLineProtocolContinue(); -}); - -When(/^click the Line Protocol wizard write button$/, async () => { - await bktTabSteps.clickLineProtocolWrite(); -}); - -When(/^click the line Protocol wizard precision "(.*)"$/, async (prec) => { - await bktTabSteps.clickLineProtocolPrecisionItem(prec); -}); - -Then(/^the line Protocol wizard second step opens$/, async() => { - await bktTabSteps.verifyLineProtocolWizardSecondStep(); -}); - -Then(/^the Line Protocol wizard step status message is "(.*)"$/, async msg => { - await bktTabSteps.verifyWizardStepStatusMessage(msg); -}); - -Then(/^the Line Protocol wizard step status message contains "(.*)"$/, async msg => { - await bktTabSteps.verifyWizardStepStatusMessageContains(msg); -}); - -When(/^click the Line Protocol wizard finish button$/, async () => { - await bktTabSteps.clickLineProtocolFinish(); -}); - -When(/^click the Line Protocol wizard close button$/, async () => { - await bktTabSteps.clickLineProtocolClose(); -}); - -When(/^click the Line Protocol wizard cancel button$/, async () => { - await bktTabSteps.clickLineProtocolCancel(); -}); - -When(/^click the Line Protocol wizard close icon$/, async () => { - await bktTabSteps.clickLineProtocolCancelIcon(); -}); - -Then(/^the line Protocol wizard is not present$/, {timeout: 2 * 5000}, async () => { - await bktTabSteps.verifyLineProtocolWizardVisible(false); -}); - -Then(/^the bucket "(.*)" for user "(.*)" contains "(.*)" datapoints of "(.*)" data with value named "(.*)" starting at "(.*)"$/, - async (bucket, user, count, mode, value, start) => { - - await bktTabSteps.verifyBucketContains((bucket === 'DEFAULT') ? __defaultUser.bucket : bucket, - (user === 'DEFAULT')? __defaultUser: await influxUtils.getUser(user), - count, mode, value, start); - }); - -Then(/^the bucket "(.*)" for user "(.*)" contains:$/, async (bucket, userName, def) => { - await bktTabSteps.verifyBucketContainsByDef(bucket,userName, def); -}); - -When(/^add the file "(.*)" to the Line Protocol Wizard file upload$/, async filePath => { - await bktTabSteps.setFileUpload(filePath); -}); - -When(/^click the bucket data wizard previous button$/, async () => { - await bktTabSteps.clickDataWizardPreviousButton(); -}); - diff --git a/e2e/src/step_definitions/loadData/clientLibStepDefs.js b/e2e/src/step_definitions/loadData/clientLibStepDefs.js deleted file mode 100644 index 33a1575bb6..0000000000 --- a/e2e/src/step_definitions/loadData/clientLibStepDefs.js +++ /dev/null @@ -1,45 +0,0 @@ -import { Then, When } from 'cucumber'; - -const clientLibsSteps = require(__srcdir + '/steps/loadData/clientLibsSteps.js'); -let clibTabSteps = new clientLibsSteps(__wdriver); - - -Then(/^the Client Libraries tab is loaded$/, async () => { - await clibTabSteps.verifyClientLibsTabIsLoaded(); -}); - -When(/^click the "(.*)" client library tile$/, async name => { - await clibTabSteps.clickLibTileByName(name); -}); - -Then(/^the csharp info popup is loaded$/, async () => { - await clibTabSteps.verifyCSharpPopupLoaded(); -}); - -Then(/^the go info popup is loaded$/, async () => { - await clibTabSteps.verifyGoPopupLoaded(); -}); - -Then(/^the java info popup is loaded$/, async () => { - await clibTabSteps.verifyJavaPopupLoaded(); -}); - -Then(/^the node info popup is loaded$/, async () => { - await clibTabSteps.verifyNodePopupLoaded(); -}); - -Then(/^the python info popup is loaded$/, async () => { - await clibTabSteps.verifyPythonPopupLoaded(); -}); - -Then(/^click copy "(.*)" to clipboard$/, {timeout: 10000}, async label => { - await clibTabSteps.clickCopyToClipboardText(label); -}); - -Then(/^verify clipboard contains text of "(.*)"$/, async label => { - await clibTabSteps.verifyClipboardTextFrom(label); -}); - -Then(/^verify the github repository link contains "(.*)"$/, async token => { - await clibTabSteps.verifyPopupGithubLink(token); -}); diff --git a/e2e/src/step_definitions/loadData/loadDataStepDefs.js b/e2e/src/step_definitions/loadData/loadDataStepDefs.js deleted file mode 100644 index 57d95f9462..0000000000 --- a/e2e/src/step_definitions/loadData/loadDataStepDefs.js +++ /dev/null @@ -1,108 +0,0 @@ -import { Then, When } from 'cucumber'; -const bucketsSteps = require(__srcdir + '/steps/loadData/bucketsSteps.js'); -const telegrafsSteps = require(__srcdir + '/steps/loadData/telegrafsSteps.js'); -const scrapersSteps = require(__srcdir + '/steps/loadData/scrapersSteps.js'); -const loadDataSteps = require(__srcdir + '/steps/loadData/loadDataSteps.js'); - -let bktTabSteps = new bucketsSteps(__wdriver); -let teleTabSteps = new telegrafsSteps(__wdriver); -let scrTabSteps = new scrapersSteps(__wdriver); -let ldSteps = new loadDataSteps(__wdriver); - -Then(/^the buckets tab is loaded$/, {timeout: 2 * 5000}, async() => { - await bktTabSteps.isLoaded(); -}); - -Then(/^the Telegraf Tab is loaded$/, {timeout: 2 * 5000}, async() => { - await teleTabSteps.isLoaded(); -}); - -Then(/^the Scrapers Tab is loaded$/, {timeout: 2 * 5000}, async() => { - await scrTabSteps.isLoaded(); -}); - -Then(/^the Create Scraper popup is loaded$/, async() => { - await ldSteps.createScraperPopupLoaded(); -}); - -When(/^dismiss the Create Scraper popup$/, async () => { - await ldSteps.dismissCreateScraperPopup(); -}); - -Then(/^the Create Scraper popup is no longer present$/, {timeout: 2 * 5000}, async () => { - await ldSteps.verifyCreateScraperPopupNotPresent(); -}); - -When(/^cancel the Create Scraper popup$/, async () => { - await ldSteps.cancelCreateScraperPopup(); -}); - -When(/^clear the Scraper Popup name input$/, async () => { - await ldSteps.clearCreateScraperNameInput(); -}); - -When(/^clear Scraper Popup the Target Url input$/, async () => { - await ldSteps.clearCreateScraperUrlInput(); -}); - -Then(/^the Create Scrapper popup create button is disabled$/, async () => { - await ldSteps.verifyCreateScraperSubmitEnabled(false); -}); - -Then(/^the Create Scrapper popup create button is enabled$/, async () => { - await ldSteps.verifyCreateScraperSubmitEnabled(true); -}); - -When(/^enter the name "(.*)" into the Create Scraper popup name input$/, async name => { - await ldSteps.enterCreateScraperName(name); -}); - -When(/^enter the value "(.*)" into the Create Scraper popup url input$/, async url => { - await ldSteps.enterCreateScraperTargetURL(url); -}); - -When(/^click the Create Scrapper buckets dropdown$/, async () => { - await ldSteps.clickCreateScraperBucketsDropdown(); -}); - -When(/^select the Scrapper buckets dropdown item "(.*)"$/, async (item) => { - await ldSteps.selectCreateScraperBucketsItem((item === 'DEFAULT') ? __defaultUser.bucket : item); -}); - -Then(/^an item for the bucket "(.*)" is an item in the buckets dropdown$/, async item => { - await ldSteps.verifyCreateScraperBucketsDropdownItem((item === 'DEFAULT') ? __defaultUser.bucket : item); -}); - -Then(/^NO items in the buckets dropdown are shown$/, async () => { - await ldSteps.verifyNoBucketItemsInBucketsDropdownShown(); -}); - -When(/^click the create scraper create button$/, async () => { - await ldSteps.clickCreateScraperBucketCreateButton(); -}); - -When(/^click load data tab "(.*)"$/, async (tab) => { - await ldSteps.clickTab(tab); -}); - -Then(/^the Create Telegraf Config Wizard is loaded$/, async () => { - await ldSteps.verifyCreateTelegrafWizardLoaded(); -}); - -When(/^click the buckets dropdown button$/, async () => { - await ldSteps.clickBucketsDropdown(); -}); - -When(/^select the buckets dropdown item "(.*)"$/, async item => { - await ldSteps.selectBucketsDropdownItem((item === 'DEFAULT') ? __defaultUser.bucket : item); -}); - -When(/^select the telegraf plugin tile "(.*)"$/, async tile => { - await ldSteps.selectTelegrafWizardPluginTile(tile); -}); - -When(/^enter the telegraf name "(.*)"$/, async name => { - await ldSteps.enterTelegrafWizardName(name); -}); - - diff --git a/e2e/src/step_definitions/loadData/scrapersStepDefs.js b/e2e/src/step_definitions/loadData/scrapersStepDefs.js deleted file mode 100644 index d911f10b55..0000000000 --- a/e2e/src/step_definitions/loadData/scrapersStepDefs.js +++ /dev/null @@ -1,97 +0,0 @@ -import { Then, When } from 'cucumber'; - -const scrapersSteps = require(__srcdir + '/steps/loadData/scrapersSteps.js'); -let scrTabSteps = new scrapersSteps(__wdriver); - - -Then(/^there is a scraper card for "(.*)"$/, {timeout: 10000}, async card => { - await scrTabSteps.verifyExistsCardByName(card); -}); - -Then(/^the scraper card named "(.*)" has the bucket "(.*)"$/, async (scraper, bucket) => { - await scrTabSteps.verifyScraperCardHasBucket(scraper, (bucket === 'DEFAULT') ? __defaultUser.bucket : bucket); -}); - -Then(/^the scraper card named "(.*)" has the endpoint "(.*)"$/, async (scraper, endpoint) => { - await scrTabSteps.verifyScraperCardHasEndpoint(scraper, endpoint); -}); - -Then(/^the scrapers tab is loaded$/, {timeout: 10000}, async () => { - await scrTabSteps.verifyScrapersTabIsLoaded(); -}); - -When(/^click the create scraper button empty$/, async () => { - await scrTabSteps.clickCreateScraperButtonEmpty(); -}); - -When(/^click the create scraper button from the header$/, async () => { - await scrTabSteps.clickCreateScraperButtonInHeader(); -}); - -Then(/^the create scraper button empty is no longer present$/, async() => { - await scrTabSteps.verifyCreateScraperEmptyNotPresent(); -}); - -Then(/^the scraper name sort order is "(.*)"$/, async(items) => { - await scrTabSteps.verifyScrapersSortOrderByName(items); -}); - -When(/^enter the value "(.*)" into the scraper filter$/, async value => { - await scrTabSteps.enterScrapersFilterValue(value); -}); - -When(/^clear the scraper filter$/, async () => { - await scrTabSteps.clearScraperFilter(); -}); - -Then(/^the scraper card "(.*)" is no longer present in the list$/, async scraper => { - await scrTabSteps.verifyScraperCardNotPresent(scraper); -}); - -When(/^click the scraper sort by name button$/, async () => { - await scrTabSteps.clickScraperNameSortButton(); -}); - -When(/^click the scraper sort By URL button$/, async() => { - await scrTabSteps.clickScraperURLSortButton(); -}); - -When(/^click the scraper sort By Bucket button$/, async() => { - await scrTabSteps.clickScraperBucketSortButton(); -}); - -When(/^hover over the scraper card name "(.*)"$/, async name => { - await scrTabSteps.mouseOverScraperCardName(name); -}); - -When(/^click the scraper card name edit control for the card "(.*)"$/, async name => { - await scrTabSteps.clickScraperCardNameEditButton(name); -}); - -When(/^Enter the value "(.*)" for the card "(.*)"$/, {timeout: 10000}, async ( newName, oldName) => { - await scrTabSteps.enterNewScraperName(newName, oldName); - //await scrTabSteps.driver.sleep(5000); -}); - -Then(/^the named query "(.*)" by user "(.*)" on the bucket "(.*)" contains the values "(.*)"$/, - async (queryName, userName, bucketName, values) => { - await scrTabSteps.verifyNamedQueryResponseValues(queryName, userName, bucketName, values); - }); - -Then(/^the delete button of the scraper card named "(.*)" is not present$/, async name => { - await scrTabSteps.verifyScraperCardDeleteNotPresent(name); -}); - -When(/^hover over scraper card named "(.*)"$/, async name => { - await scrTabSteps.hoverOverScraperCard(name); -}); - -When(/^click the delete button of the scraper card named "(.*)"$/, async name => { - await scrTabSteps.clickScraperCardDeleteButton(name); -}); - -When(/^click the confirm delete button of the scraper card named "(.*)"$/, async name => { - await scrTabSteps.clickScraperCardDeleteConfirm(name); -}); - - diff --git a/e2e/src/step_definitions/loadData/telegrafStepDefs.js b/e2e/src/step_definitions/loadData/telegrafStepDefs.js deleted file mode 100644 index f380d74648..0000000000 --- a/e2e/src/step_definitions/loadData/telegrafStepDefs.js +++ /dev/null @@ -1,299 +0,0 @@ -import { Then, When } from 'cucumber'; - -const telegrafsSteps = require(__srcdir + '/steps/loadData/telegrafsSteps.js'); - -let teleTabSteps = new telegrafsSteps(__wdriver); - -Then(/^there is a telegraf card for "(.*)"$/, async name => { - - await teleTabSteps.verifyTelegrafCardByName(name); - -}); - -Then(/^the telegrafs tab is loaded$/, async () => { - await teleTabSteps.verifyTelegrafTabLoaded(true); -}); - -When(/^click the create Telegraf button empty$/, async () => { - await teleTabSteps.clickCreateTelegrafButtonEmpty(); -}); - -When(/^click telegraf card "(.*)"$/, async (name) => { - await teleTabSteps.clickTelegrafCard(name); -}); - -When(/^click the create Telegraf button in header$/, async () => { - await teleTabSteps.clickCreateTelegrafButtonInHeader(); -}); - -Then(/^the Create Telegraf Wizard is loaded$/, { timeout: 10000 }, async () => { - await teleTabSteps.verifyWizardLoadedP1(); -}); - -When(/^dismiss the Create Telegraf Wizard$/, async () => { - await teleTabSteps.dismissPopup(); -}); - -Then(/^the Create Telegraf Wizard is no longer present$/, { timeout: 10000 }, async () => { - await teleTabSteps.verifyCreateTelegrafWizardNotPresent(); -}); - -When(/^click the select bucket dropdown in the Create Telegraf Wizard$/, async () => { - await teleTabSteps.clickCreateConfigBucketDropdown(); -}); - -When(/^click the bucket item "(.*)" in the Create Telegraf Wizard$/, async item => { - await teleTabSteps.clickCreateConfigBucketDropdownItem((item === 'DEFAULT') ? __defaultUser.bucket : item); -}); - -When(/^click the plugin tile "(.*)" in the Create Telegraf Wizard$/, async plugin => { - await teleTabSteps.clickCreateConfigPluginTile(plugin); -}); - -When(/^clear the create Telegraf Wizard plugin filter$/, async () => { - await teleTabSteps.clearWizardPluginFilter(); -}); - -When(/^enter the value "(.*)" in create Telegraf Wizard filter plugins$/, async value => { - await teleTabSteps.enterValueIntoPluginsFilter(value); -}); - -Then(/^the Create Telegraf wizard plugin tile "(.*)" is visible$/, async plugin => { - await teleTabSteps.verifyCreateWizardPluginTileVisible(plugin); -}); - -Then(/^the Create Telegraf wizard plugin tile "(.*)" is not present$/, async plugin => { - await teleTabSteps.verifyCreateWizardPluginTileNotPresent(plugin); -}); - -Then(/^the create Telegraf Wizard second step is loaded$/, {timeout: 10000}, async () => { - await teleTabSteps.verifyCreateWizardStep2Loaded(); -}); - -Then(/^the create Telegraf plugins sidebar contains "(.*)"$/, - async plugins => { - await teleTabSteps.verifyCreateWizardStep2PluginsList(plugins.toLowerCase()); - }); - -Then(/^the create Telegraf plugin sidebar "(.*)" item is in state "(.*)"$/, async (plugin, state) => { - await teleTabSteps.verifyCreateWizardPluginState(plugin, state); -}); - -When(/^click the create Telegraf plugin sidebar "(.*)" item$/, async plugin => { - await teleTabSteps.clickCreateWizardPluginItem(plugin); -}); - -Then(/^the create Telegraf edit plugin "(.*)" step is loaded$/, {timeout: 10000}, async plugin => { - await teleTabSteps.verifyEditPluginStepLoaded(plugin); -}); - -Then(/^the Create Telegraf wizard plugin tile "(.*)" is selected$/, async plugin => { - await teleTabSteps.verifyCreateWizardPluginTileSelected(plugin); -}); - -Then(/^the Create Telegraf wizard plugin tile "(.*)" is not selected$/, async plugin => { - await teleTabSteps.verifyCreateWizardPluginTileNotSelected(plugin); -}); - -When(/^enter the values (.*) into the fields (.*)$/, async (values, fields) => { - await teleTabSteps.enterValuesIntoFields(values, fields); -}); - -When(/^click the NGINX configuration add button$/, async () => { - await teleTabSteps.clickNGINXConfigAddUrlButton(); -}); - -Then(/^the NGINX configuration URLs list contains "(.*)" items$/, async ct => { - await teleTabSteps.verifyNGINXConfUrlsListSize(ct); -}); - -Then(/^the NGINX configuration URLs list is empty$/, async () => { - await teleTabSteps.verifyNGINXConfUrlsListEmpty(); -}); - -When(/^click delete for the first NGINX configuration URL$/, async () => { - await teleTabSteps.clickNGINXConfUrlsFirstDelete(); -}); - -When(/^click confirm delete of NGINX configuration URL$/, async () => { - await teleTabSteps.clickNGINXConfUrlDeleteConfirm(); -}); - -Then(/^verify the edit plugin error notification with message "(.*)"$/, async msg => { - await teleTabSteps.verifyEditPluginErrorMessage(msg); -}); - -When(/^clear the create Telegraf edit plugin fields (.*)$/, async fields => { - await teleTabSteps.clearCreateTelegrafPluginFields(fields); -}); - -When(/^enter the name "(.*)" in the Create Telegraf Wizard$/, async name => { - await teleTabSteps.enterTelegrafWizardName(name); -}); - -When(/^enter the description "(.*)" in the Create Telegraf Wizard$/, async descr => { - await teleTabSteps.enterTelegrafWizardDescr(descr); -}); - -When(/^click the Create Telegraf Wizard finish button$/, async () => { - await teleTabSteps.clickPopupWizardFinish(); -}); - -Then(/^the create Telegraf Wizard final step is loaded$/, async () => { - await teleTabSteps.verifyCreateWizardStep3Loaded(); -}); - -Then(/^the bucket of the telegraf card "(.*)" is "(.*)"$/, async (name, bucket) => { - await teleTabSteps.verifyBucketForTelegrafCard(name, (bucket === 'DEFAULT') ? __defaultUser.bucket : bucket); -}); - -Then(/^the description of the telegraf card "(.*)" is "(.*)"$/, async (name, descr) => { - await teleTabSteps.verifyDescriptionForTelegrafCard(name, descr); -}); - -Then(/^the telegraf sort order is "(.*)"$/, async order => { - await teleTabSteps.verifyTelegrafCardSortOrder(order); -}); - -When(/^click the telegraf sort by name button$/, async () => { - await teleTabSteps.clickTelegrafSortByName(); -}); - -When(/^click the telegraf sort by bucket button$/, async () => { - await teleTabSteps.clickTelegrafSortByBucket(); -}); - -When(/^enter the value "(.*)" into the Telegrafs filter$/, async value => { - await teleTabSteps.enterTelegrafsFilterValue(value); -}); - -When(/^clear the Telegrafs filter$/, async () => { - await teleTabSteps.clearTelegrafsFilter(); -}); - -When(/^click on setup instructions for the telegraf card "(.*)"$/, async card => { - await teleTabSteps.clickSetupInstructionsForCard(card); -}); - -Then(/^the telegraf setup instruction popup is loaded$/, async () => { - await teleTabSteps.verifyTelegrafSetupPopup(); -}); - -When(/^click on the name of the telegraf card "(.*)"$/, async name => { - await teleTabSteps.clickTelegrafCardNamed(name); -}); - -When(/^hover over the name of the telegraf card "(.*)"$/, async name => { - await teleTabSteps.hoverOverTelegrafCardName(name); -}); - -Then(/^the telegraf configuration popup for "(.*)" is loaded$/, async name => { - await teleTabSteps.verifyTelegrafConfigPopup(name); -}); - -When(/^click the name edit icon of the telegraf card "(.*)"$/, async name => { - await teleTabSteps.clickNameEditIconOfTelegrafCard(name); -}); - -When(/^clear the name input of the telegraf card "(.*)"$/, async name => { - await teleTabSteps.clearTelegrafCardNameInput(name); -}); - -When(/^clear the desrciption input of the telegraf card "(.*)"$/, async card => { - await teleTabSteps.clearTelegrafCardDescrInput(card); -}); - -When(/^set the name input of the telegraf card "(.*)" to "(.*)"$/, async (oldName, newName) => { - await teleTabSteps.setNameInputOfTelegrafCard(oldName, newName); -}); - -When(/^set the description input of the telegraf card "(.*)" to "(.*)"$/, async (name, descr) => { - await teleTabSteps.setDescriptionInputOfTelegrafCard(name, descr); -}); - -Then(/^the Telegraf Card "(.*)" can no longer be found$/, async name => { - await teleTabSteps.verifyTelegrafCardNotPresent(name); -}); - -Then(/^the telegraf cards "(.*)" are no longer present$/, {timeout: 20000}, async names => { - let nameArr = names.split(','); - for(let i = 0; i < nameArr.length; i++){ - await teleTabSteps.verifyTelegrafCardNotPresent(nameArr[i]); - } -}); - -When(/^hover over the description of the telegraf Card "(.*)"$/, async card => { - await teleTabSteps.hoverOverTelegrafCardDescription(card); -}); - -When(/^click the description edit icon of the telegraf card "(.*)"$/, async card => { - await teleTabSteps.clickDescrEditIconOfTelegrafCard(card); -}); - -When(/^hover over telegraf card "(.*)"$/, async name => { - await teleTabSteps.hoverOverTelegrafCard(name); -}); - -When(/^click delete for telegraf card "(.*)"$/, async name => { - await teleTabSteps.clickTelegrafCardDelete(name); -}); - -When(/^click delete confirm for telegraf card "(.*)"$/, async name => { - await teleTabSteps.clickTelegrafCardDeleteConfirm(name); -}); - -When(/^click Add Label for Telegraf Card "(.*)"$/, async name => { - await teleTabSteps.clickTelegrafCardAddLabel(name); -}); - -Then(/^the Label Popup for the Telegraf Card "(.*)" is not present$/, async name => { - await teleTabSteps.verifyTelegrafCardLabelPopupNotPresent(name); -}); - -Then(/^the Label Popup for the Telegraf Card "(.*)" is visible$/, async name => { - await teleTabSteps.verifyTelegrafCardLabelPopupIsVisible(name); -}); - -Then(/^the item "(.*)" is in the Telegraf Card "(.*)" label select list$/, async (item, name) => { - await teleTabSteps.verifyTelegrafCardLabelPopupSelectItem(name, item); -}); - -Then(/^the item "(.*)" is NOT in the Telegraf Card "(.*)" label select list$/, async (item, name) => { - await teleTabSteps.verifyTelegrafCardLabelPopupSelectItemNotPresent(name, item); -}); - -When(/^filter the Telegraf Card "(.*)" label list with "(.*)"$/, async (name, term ) => { - await teleTabSteps.filterTelegrafCardLabeList(name, term); -}); - -When(/^enter the value "(.*)" into the Telegraf Card "(.*)" label filter$/, async (term, name) => { - await teleTabSteps.enterTermIntoTelegrafCardLabelFilter(name, term); -}); - -When(/^clear the label filter of the Telegraf Card "(.*)"$/, async name => { - await teleTabSteps.clearTelegrafCardLabelFilter(name); -}); - -When(/^click the item "(.*)" is in the Telegraf Card "(.*)" label select list$/, async (item, name) => { - await teleTabSteps.clickTelegrafCardLabelPopupSelectItem(name, item); -}); - -Then(/^there is a label pill "(.*)" for the Telegraf Card "(.*)"$/, async (item, name) => { - await teleTabSteps.verifyTelegrafCardLabelPillIsVisible(name, item); -}); - -Then(/^the label select list for "(.*)" shows the empty state message$/, async name => { - await teleTabSteps.verifyTelegrafCardLabelListEmptyMsg(name); -}); - -When(/^hover over the label pill "(.*)" for the Telegraf Card "(.*)"$/, async (label, name) => { - await teleTabSteps.hoverTelegrafCardLabelPill(name, label); -}); - -When(/^click delete the label pill "(.*)" for the Telegraf Card "(.*)"$/, async (label, name) => { - await teleTabSteps.clickTelegrafCardLabelPillDelete(name, label); -}); - -Then(/^the label pill "(.*)" for the Telegraf Card "(.*)" is NOT present$/, async (label, name) => { - await teleTabSteps.verifyTelegrafCardLabelPillNotPresent(name, label); -}); diff --git a/e2e/src/step_definitions/loadData/tokensStepDefs.js b/e2e/src/step_definitions/loadData/tokensStepDefs.js deleted file mode 100644 index 2c05cd9bc0..0000000000 --- a/e2e/src/step_definitions/loadData/tokensStepDefs.js +++ /dev/null @@ -1,221 +0,0 @@ -import { Then, When } from 'cucumber'; - -const tokensSteps = require(__srcdir + '/steps/loadData/tokensSteps.js'); - -let tknSteps = new tokensSteps(__wdriver); - -Then(/^the tokens tab is loaded$/, {timeout: 10000}, async () => { - await tknSteps.isLoaded(); -}); - -Then(/^the tokens list contains the token described as "(.*)"$/, async descr => { - await tknSteps.verifyTokenInListByDescr(descr); -}); - -When(/^click the generate token dropdown$/, async () => { - await tknSteps.clickGenerateTokenDropdown(); -}); - -When(/^click the generate token item "(.*)"$/, async item => { - await tknSteps.clickGenerateTokenItem(item); -}); - -When(/^select token type based on (.*) type$/, async privilege => { - if(privilege.toLowerCase() === 'all'){ - await tknSteps.clickGenerateTokenItem('all-access'); - }else{ - await tknSteps.clickGenerateTokenItem('read-write'); - } -}); - -Then(/^the generate read-write token popup is loaded$/, async () => { - await tknSteps.verifyGenReadWriteTokenPopup(); -}); - -Then(/^the generate all-access token popup is loaded$/, async () => { - await tknSteps.verifyAllAccessTokenPopup(); -}); - -When(/^click the "(.*)" radio button "(.*)"$/, async (mode, set) => { - await tknSteps.clickModeScopeRadioButton(mode, set); -}); - -Then(/^the "(.*)" panel shows the empty state text$/, async mode => { - await tknSteps.verifyPanelEmptyState(mode); -}); - -Then(/^the tokens list does not contain the token described as "(.*)"$/, async descr => { - await tknSteps.verifyTokenCardNotPresent(descr); -}); - -Then(/^the "(.*)" panel bucket selector is present$/, async mode => { - await tknSteps.verifyBucketSelectorVisible(mode); -}); - -Then(/^the bucket selector for the "(.*)" panel is not present$/, async mode => { - await tknSteps.verifyBucketSelectorNotPresent(mode); -}); - -Then(/^the "(.*)" panel empty state text is not present$/, async mode => { - await tknSteps.verifyEmptyStateTextNotPresent(mode); -}); - -Then(/^the "(.*)" panel bucket list contains "(.*)"$/, async (mode, buckets) => { - await tknSteps.verifyPanelBucketList(mode, buckets.replace('DEFAULT', __defaultUser.bucket)); -}); - -When(/^filter the "(.*)" panel bucket selector with "(.*)"$/, {timeout: 10000 }, async (mode, term) => { - await tknSteps.filterPanelBucketsSelector(mode, term); - // await tknSteps.delay(5000) -}); - -Then(/^the "(.*)" panel bucket list does not contain "(.*)"$/, {timeout: 10000}, async (mode, buckets) => { - await tknSteps.verifyPanelBucketsNotPresent(mode, buckets.replace('DEFAULT', __defaultUser.bucket)); -}); - -When(/^clear the "(.*)" panel bucket selector$/, async mode => { - await tknSteps.clearPanelBucketsSelector(mode); -}); - -When(/^click "(.*)" panel select all buckets$/, async mode => { - await tknSteps.clickSelectAllBuckets(mode); -}); - -When(/^click "(.*)" panel deselect all buckets$/, async mode => { - await tknSteps.clickDeselectAllBuckets(mode); -}); - -When(/^click the "(.*)" panel bucket "(.*)"$/, async (mode, bucket) => { - await tknSteps.clickTokenPopupSelectBucket(mode, bucket); -}); - -Then(/^the "(.*)" panel buckets "(.*)" are selected$/, async (mode,buckets) => { - await tknSteps.verifyPanelBucketsSelected(mode, buckets.replace('DEFAULT', __defaultUser.bucket)); -}); - -Then(/^the "(.*)" panel buckets "(.*)" are not selected$/, async (mode, buckets) => { - await tknSteps.verifyPanelBucketsNotSelected(mode, buckets.replace('DEFAULT', __defaultUser.bucket)); -}); - -When(/^click all-access token popup cancel$/, async () => { - await tknSteps.clickAllAccessPopupCancel(); -}); - -When(/^set token description for (.*) as (.*)$/, async (privilege, description) => { - if(privilege.toLowerCase() === 'all'){ - await tknSteps.setAllAccessTokenDescription(description); - }else{ - await tknSteps.setReadWriteTokenDescription(description); - } -}); - -When(/^set token privileges for (.*) as (.*)$/, async (bucket, privileges) => { - let bkt = (bucket === 'DEFAULT') ? __defaultUser.bucket : bucket; - - if(privileges.toLowerCase() === 'all'){ - // nothing to do - }else{ - if(privileges.toLowerCase().includes('r')){ //Read Privileges - if(bkt.toLowerCase() === 'all'){ - await tknSteps.clickModeScopeRadioButton('Read', 'All Buckets'); - }else{ - await tknSteps.clickTokenPopupSelectBucket('Read', bkt); - } - } - - if(privileges.toLowerCase().includes('w')){ //Write Privileges - if(bkt.toLowerCase() === 'all'){ - await tknSteps.clickModeScopeRadioButton('Write', 'All Buckets'); - }else{ - await tknSteps.clickTokenPopupSelectBucket('Write', bkt); - } - } - } - -}); - -When(/^click popup save based on (.*)$/, async privileges => { - - if(privileges.toLowerCase() === 'all'){ - await tknSteps.clickGenerateTokenAllAccessSave(); - }else{ - await tknSteps.clickGenerateTokenReadWriteSave(); - } -}); - -When(/^disable the token described as (.*)$/, async descr => { - await tknSteps.disableTokenInList(descr); -}); - -When(/^enable the token described as "(.*)"$/, async descr => { - await tknSteps.enableTokenInList(descr); -}); - -Then(/^the token described as (.*) is disabled$/, async descr => { - await tknSteps.verifyTokenIsDisabled(descr); -}); - -Then(/^the token described as "(.*)" is enabled$/, async descr => { - await tknSteps.verifyTokenIsEnabled(descr); -}); - -Then(/^the first tokens are sorted by description as "(.*)"$/, async list => { - await tknSteps.verifyTokenSortOrder(list); -}); - -When(/^click the tokens sorter button$/, async () => { - await tknSteps.clickTokensSorterButton(); -}); - -When(/^click the tokens sorter item "(.*)"$/, async item => { - await tknSteps.clickTokensSorterItem(item); -}); - -When(/^click the tokens sort By Name button$/, async () => { - await tknSteps.clickTokensSortByName(); -}); - -When(/^hover over the token description "(.*)"$/, async descr => { - await tknSteps.hoverOverTokenDescription(descr); -}); - -When(/^click the token description toggle for "(.*)"$/, async descr => { - await tknSteps.clickTokenDescriptionEditToggle(descr); -}); - -When(/^clear the edit input for description "(.*)"$/, async descr => { - await tknSteps.clearTokenDescriptionInput(descr); -}); - -When(/^set the new description of "(.*)" to "(.*)"$/, async (oldDescr, newDescr) => { - await tknSteps.resetTokenDescription(oldDescr, newDescr); -}); - -When(/^click on the token described as "(.*)"$/, async descr => { - await tknSteps.clickTokenDescription(descr); -}); - -Then(/^the review token popup is loaded$/, async () => { - await tknSteps.verifyReviewTokenPopupLoaded(); -}); - -Then(/^the review token popup matches "(.*)" and "(.*)"$/, async (buckets, privileges) => { - await tknSteps.verifyReviewTokenBuckets(buckets.replace('DEFAULT', __defaultUser.bucket ), privileges); -}); - -When(/^hover over token card described as "(.*)"$/, async descr => { - await tknSteps.hoverOverTokenCard(descr); -}); - -When(/^click the delete button of the token card described as "(.*)"$/, async descr => { - await tknSteps.clickTokenCardDeleteButton(descr); -}); - -//Deprecated - todo clean -When(/^click delete confirm of the token card described as "(.*)"$/, async descr => { - await tknSteps.clickTokenCardDeleteConfirm(descr); -}); - -When(/^click token card popover delete confirm$/, async () => { - await tknSteps.clickTokenCardPopoverDeleteConfirm(); -}); diff --git a/e2e/src/step_definitions/monitoring/checkEditStepDefs.js b/e2e/src/step_definitions/monitoring/checkEditStepDefs.js deleted file mode 100644 index 59038d0960..0000000000 --- a/e2e/src/step_definitions/monitoring/checkEditStepDefs.js +++ /dev/null @@ -1,230 +0,0 @@ -import { Then, When } from 'cucumber'; -const checkEditSteps = require(__srcdir + '/steps/monitoring/checkEditSteps.js'); - -let ckEdSteps = new checkEditSteps(__wdriver); - -Then(/^the edit check overlay is loaded$/, async() => { - await ckEdSteps.isLoaded(); - await ckEdSteps.verifyIsLoaded(); -}); - -Then(/^the edit check overlay is not loaded$/, async () => { - await ckEdSteps.verifyIsNotLoaded(); -}); - -When(/^click the check editor save button$/, async () => { - await ckEdSteps.clickCKEdSaveButton(); -}); - -When(/^dismiss edit check overlay$/, async () => { - await ckEdSteps.dismissOverlay(); -}); - -When(/^enter the alert check name "(.*)"$/, async name => { - await ckEdSteps.enterAlertCheckName(name); -}); - -Then(/^the current edit check name is "(.*)"$/, async name => { - await ckEdSteps.verifyEditCheckName(name); -}); - -When(/^click check editor configure check button$/, async () => { - await ckEdSteps.clickCkEdConfigureCheck(); -}); - -When(/^click checkeditor define query button$/, async () => { - await ckEdSteps.clickDefineQuery(); -}); - -Then(/^the configure check view is loaded$/, async () => { - await ckEdSteps.verifyConfigureCheckStepLoaded(); -}); - -Then(/^the create check checklist contains:$/, async items => { - await ckEdSteps.verifyChecklistPopoverItems(items); -}); - -Then(/^the create check checklist is not present$/, async () => { - await ckEdSteps.verifyConfigureCheckListPopoverNotPresent(); -}); - -Then(/^the save check button is disabled$/, async () => { - await ckEdSteps.verifySaveCheckDisabled(); -}); - -Then(/^the save check button is enabled$/, async () => { - await ckEdSteps.verifySaveCheckEnabled(); -}); - -Then(/^the interval indicator is set to "(.*)"$/, async duration => { - await ckEdSteps.verifyCkEdIntervalInput(duration); -}); - -When(/^click on check interval input$/, async () => { - await ckEdSteps.clickCkEdIntervalInput(); -}); - -When(/^set the check interval input to "(.*)"$/, async duration => { - await ckEdSteps.setCheckIntervalInput(duration); -}); - -When(/^enter into interval offset "(.*)"$/, async offset => { - await ckEdSteps.enterIntoIntervalOffset(offset); -}); - -Then(/^the check interval hint dropdown list is not visible$/, async () => { - await ckEdSteps.verifyCkEdHintDropdownNotVisible(); -}); - -Then(/^the check interval hint dropdown list includes$/, async items => { - await ckEdSteps.verifyCkEdHintDropdownItems(items); -}); - -When(/^click the interval hint dropdown list item "(.*)"$/, async item => { - await ckEdSteps.clickCkEdHintDropdownItem(item); -}); - -When(/^click the check offset interval input$/, async () => { - await ckEdSteps.clickCkEdOffsetInput(); -}); - -When(/^set the check offset interval input "(.*)"$/, async val => { - await ckEdSteps.setCheckOffsetInput(val); -}); - -Then(/^the check offset hint dropdown list is not visible$/, async () => { - await ckEdSteps.verifyCkEdHintDropdownNotVisible(); -}); - -Then(/^the check offset hint dropdown list includes$/, async items => { - await ckEdSteps.verifyCkEdHintDropdownItems(items); -}); - -When(/^click the offset hint dropdown list item "(.*)"$/, async item => { - await ckEdSteps.clickCkEdHintDropdownItem(item); -}); - -Then(/^the offset input is set to "(.*)"$/, async val => { - ckEdSteps.verifyCkEdOffsetInput(val); -}); - -When(/^update the check message template to$/, async content => { - await ckEdSteps.updateChecMessageTemplateContent(content); -}); - -Then(/^the check message tempate contains$/, async content => { - await ckEdSteps.verifyCheckMessageTemplateContent(content); -}); - -When(/^click add threshold condition "(.*)"$/, async threshold => { - await ckEdSteps.clickAddThresholdCondition(threshold); -}); - -When(/^click the threshold definition dropdown for condition "(.*)"$/, async threshold => { - await ckEdSteps.clickThresholdDefinitionDropdown(threshold); -}); - -Then(/^the threshold definition dropdown for "(.*)" contain items:$/, async (threshold, items) => { - await ckEdSteps.verifyThresholdDefinitionDropdownItems(threshold,items); -}); - -When(/^click the threshold definition dropodown item "(.*)" for condition "(.*)"$/, - async (item, threshold) => { - await ckEdSteps.clickThresholdDefinitionDropdownItem(threshold, item); -}); - -When(/^set the unary boundary value for the threshold definition "(.*)" to "(.*)"$/, - async (threshold, val1) => { - await ckEdSteps.setUnaryThresholdBoundaryValue(threshold, val1); -}); - -Then(/^there is a binary boundary for the threshold "(.*)" with values "(.*)" and "(.*)"$/, - async (threshold, lower, upper) => { - await ckEdSteps.verifyBinaryThresholdBoundaryValues(threshold, lower, upper); -}); - -Then(/^there is a unary boundary for the threshhold "(.*)" with the value "(.*)"$/, async (threshold, val) => { - await ckEdSteps.verifyUnaryThresholdBoundaryValue(threshold, val); -}); - -When(/^set the binary boundary for the threshold "(.*)" from "(.*)" to "(.*)"$/, - async (threshold, lower, upper) => { - await ckEdSteps.setBinaryThresholdBoundaryValues(threshold, lower, upper); -}); - -When(/^click the deadman definition No Values For input$/, async () => { - await ckEdSteps.clickNoValuesForDurationInput(); -}); - -When(/^set the value of the deadman definition No Values for input to "(.*)"$/, async val => { - await ckEdSteps.setValueNoValuesForDurationInput(val); -}); - -Then(/^the deadman definition hints dropdown contains:$/, async items => { - await ckEdSteps.verifyNoValuesForDurationHintItems(items); -}); - -When(/^click the deadman definition hint dropdown item "(.*)"$/, async item => { - await ckEdSteps.clickNoValuesForDurationHintItem(item); -}); - -Then(/^the deadman definition No Values For input contains "(.*)"$/, async val => { - await ckEdSteps.verifyValueOfNoValuesForDurationInput(val); -}); - -When(/^click the deadman definition level dropdown$/, async () => { - await ckEdSteps.clickDefinitionLevelDropdown(); -}); - -Then(/^the deadman definition level dropdown contains:$/, async items => { - await ckEdSteps.verifyDefinitionLevelDropdownItems(items); -}); - -When(/^click the deadman definition level dropdown item "(.*)"$/, async item => { - await ckEdSteps.clickDefinitionLevelDropdownItem(item); -}); - -Then(/^the deadman definition level dropdown selected item is "(.*)"$/, async val => { - await ckEdSteps.verifyDefinitionLevelDropdownSelected(val); -}); - -When(/^click the deadman definition Stop Checking input$/, async () => { - await ckEdSteps.clickStopCheckingDurationInput(); -}); - -Then(/^the deadman definition stop hints dropdown contains:$/, async items => { - await ckEdSteps.verifyDefinitionStopDropdownItems(items); -}); - -When(/^click the deadman definition stop hint dropdown item "(.*)"$/, async item => { - await ckEdSteps.clickDefinitionStopDropdownItem(item); -}); - -Then(/^the deadman definition stop input contains "(.*)"$/, async val => { - await ckEdSteps.verifyDefinitionStopInputValue(val); -}); - -When(/^set the value of the definition stop input to "(.*)"$/, async val => { - await ckEdSteps.setValueDefinitionStopInput(val); -}); - -Then(/^the time machine cell edit preview contains threshold markers:$/, async markers => { - await ckEdSteps.verifyCellEditPreviewThresholdMarkers(markers); -}); - -When(/^click the edit check add tag button$/, async () => { - await ckEdSteps.clickAddTag(); -}); - -When(/^set the check tag key of tag "(.*)" to "(.*)"$/, async (index, key) => { - await ckEdSteps.setCheckTagKey(index, key); -}); - -When(/^set the check tag value of tag "(.*)" to "(.*)"$/, async (index,val) => { - await ckEdSteps.setCheckTagVal(index, val); -}); - -When(/^remove check tag key "(.*)"$/, async index => { - await ckEdSteps.removeCheckTag(index); -}); - diff --git a/e2e/src/step_definitions/monitoring/checkStatusHistoryStepDefs.js b/e2e/src/step_definitions/monitoring/checkStatusHistoryStepDefs.js deleted file mode 100644 index 40b76e1934..0000000000 --- a/e2e/src/step_definitions/monitoring/checkStatusHistoryStepDefs.js +++ /dev/null @@ -1,73 +0,0 @@ -import { Then, When } from 'cucumber'; -const checkStatusHistorySteps = require(__srcdir + '/steps/monitoring/checkStatusHistorySteps.js'); - -let ckStatHistSteps = new checkStatusHistorySteps(__wdriver); - -Then(/^the Check statusses page is loaded$/, {timeout: 10000}, async() => { - await ckStatHistSteps.isLoaded(); - await ckStatHistSteps.verifyIsLoaded(); -}); - -Then(/^there are at least "(.*)" events in the history$/, async count => { - await ckStatHistSteps.verifyMinimumEvents(count); -}); - -Then(/^event no "(.*)" contains the check name "(.*)"$/, async (index, name) => { - await ckStatHistSteps.verifyEventName(index, name); -}); - -When(/^click the check name of event no "(.*)"$/, async index => { - await ckStatHistSteps.clickEventName(index); -}); - -Then(/^there is at least "(.*)" events at level "(.*)"$/, async (count, level) => { - await ckStatHistSteps.verifyMinimumCountEventsAtLevel(count, level); -}); - -When(/^click event history filter input$/, async () => { - await ckStatHistSteps.clickEventFilterInput(); -}); - -Then(/^the event history examples dropdown is visible$/, async () => { - await ckStatHistSteps.verifyFilterExamplesDropdownVisible(); -}); - -Then(/^the event history examples dropdown is not visible$/, async () => { - await ckStatHistSteps.verifyFilterExamplesDropdownNotVisible(); -}); - -When(/^get events history graph area$/, async () => { - await ckStatHistSteps.getEventsHistoryGraph(); -}); - -Then(/^the events history graph has changed$/, async () => { - await ckStatHistSteps.verifyEventsHistoryGraphChanged(); -}); - -When(/^get event marker types and locations$/, async () => { - await ckStatHistSteps.getEventMarkerTypesAndLocations(); -}); - -When(/^click the alert history title$/, async () => { - await ckStatHistSteps.clickAlertHistoryTitle(); -}); - -When(/^zoom into event markers$/, async () => { - await ckStatHistSteps.zoomInOnEventMarkers(); -}); - -Then(/^the event marker locations have changed$/, async () => { - await ckStatHistSteps.verifyEventMarkerLocationChanges(); -}); - -Then(/^the event toggle "(.*)" is off$/, async event => { - await ckStatHistSteps.verifyEventToggleOff(event); -}); - -Then(/^the event toggle "(.*)" is on$/, async event => { - await ckStatHistSteps.verifyEventToggleOn(event); -}); - -When(/^double click history graph area$/, async () => { - await ckStatHistSteps.doubleClickHistoryGraph(); -}); diff --git a/e2e/src/step_definitions/monitoring/monitoringStepDefs.js b/e2e/src/step_definitions/monitoring/monitoringStepDefs.js deleted file mode 100644 index 611b3041f7..0000000000 --- a/e2e/src/step_definitions/monitoring/monitoringStepDefs.js +++ /dev/null @@ -1,208 +0,0 @@ -import { Then, When } from 'cucumber'; -const monitoringSteps = require(__srcdir + '/steps/monitoring/monitoringSteps.js'); - -let monSteps = new monitoringSteps(__wdriver); - -Then(/^the Alerting page is loaded$/, async() => { - await monSteps.isLoaded(); - await monSteps.verifyIsLoaded(); -}); - - -Then(/^the notification rules create dropdown is disabled$/, async () => { - await monSteps.verifyNotifyRulesCreateDropdownDiabled(); -}); - -When(/^click alerting tab "(.*)"$/, async tabName => { - await monSteps.clickAlertingTab(tabName); -}); - -When(/^click the create check button$/, async () => { - await monSteps.clickCreateCheckButton(); -}); - -When(/^click the create check dropdown item "(.*)"$/, async item => { - await monSteps.clickCreateCheckDropdownItem(item); -}); - -Then(/^the create check dropodown list contains the items$/, async items => { - await monSteps.verifyCreateCheckDropdownItems(items); -}); - -Then(/^the create check dropdown list is not visible$/, async () => { - await monSteps.verifyCreateCheckDropdownNotVisible(); -}); - -When(/^hover the create check question mark$/, async () => { - await monSteps.hoverCreateCheckQMark(); -}); - -Then(/^the create check tooltip is visible$/, async () => { - await monSteps.verifyCreateCheckTooltipVisible(); -}); - -Then(/^the create check tooltip is not visible$/, async () => { - await monSteps.verifyCreateCheckTooltipNotVisible(); -}); - -When(/^hover the alerts page title$/, async () => { - await monSteps.hoverPageTitle(); -}); - -When(/^hover the create endpoint question mark$/, async () => { - await monSteps.hoverCreateEndpointQMark(); -}); - -Then(/^the create endpoint tooltip is visible$/, async () => { - await monSteps.verifyCreateEndpointTooltipVisible(); -}); - -Then(/^the create endpoint tooltip is not visible$/, async () => { - await monSteps.verifyCreateEndpointTooltipNotVisible(); -}); - -When(/^hover the create rule question mark$/, async () => { - await monSteps.hoverCreateRuleQMark(); -}); - -Then(/^the create rules tooltip is visible$/, async () => { - await monSteps.verifyCreateRuleTooltipVisible(); -}); - -Then(/^the create rules tooltip is not visible$/, async () => { - await monSteps.verifyCreateRuleTooltipNotVisible(); -}); - -When(/^click create endpoint button$/, async () => { - await monSteps.clickCreateEndpointButton(); -}); - -Then(/^the create endpoint popup is loaded$/, async () => { - await monSteps.verifyCreateEndpointPopupLoaded(); -}); - -When(/^click the first time create threshold check$/, async() => { - await monSteps.clickFirstTimeCreateThresholdCheck(); -}); - -Then(/^the first time create threshold check is visible$/, async () => { - await monSteps.verifyFirstTimeCreateThresholdCheckVisible(); -}); - -When(/^click the first time create deadman check$/, async () => { - await monSteps.clickFirstTimeCreateDeadmanCheck(); -}); - -Then(/^the first time create deadman check is visible$/, async () => { - await monSteps.verifyFirstTimeCreateDeadmanCheckVisible(); -}); - -Then(/^there is an alert card named "(.*)"$/, async name => { - await monSteps.verifyAlertCardName(name); -}); - -When(/^hover over the name of the check card "(.*)"$/, async name => { - await monSteps.hoverOverCheckCardName(name); -}); - -When(/^click the check card name "(.*)"$/, async name => { - await monSteps.clickCheckCardName(name); -}) - -When(/^click the name edit button of the check card "(.*)"$/, async name => { - await monSteps.clickCheckCardNameEditButton(name); -}); - -When(/^update the active check card name input to "(.*)"$/, async newVal => { - await monSteps.updateCheckCardActiveNameInput(newVal); -}); - -When(/^hover over the description of the check card "(.*)"$/, async name => { - await monSteps.hoverOverCheckCardDescription(name); -}); - -When(/^click the description edit button of the check card "(.*)"$/, async name => { - await monSteps.clickCheckCardDescriptionEditButton(name); -}); - -When(/^update the active check card description input to:$/, async text => { - await monSteps.updateCheckCardActiveDescription(text); -}); - -Then(/^the check card "(.*)" contains the description:$/, async (name,text) => { - await monSteps.verifyCheckCardDescription(name, text); -}); - -When(/^click empty label for check card "(.*)"$/, async name => { - await monSteps.clickCheckCardEmptyLabel(name); -}); - -When(/^click the checks filter input$/, async () => { - await monSteps.clickChecksFilterInput(); -}); - -When(/^click the add labels button for check card "(.*)"$/, async name => { - await monSteps.clickCheckCardAddLabels(name); -}); - -Then(/^the check card "(.*)" contains the label pills:$/, async (name,labels) => { - await monSteps.verifyCheckCardLabels(name,labels); -}); - -When(/^remove the label pill "(.*)" from the check card "(.*)"$/, async (label, name) => { - await monSteps.removeLabelPillFromCheckCard(name,label); -}); - -Then(/^the check card "(.*)" does not contain the label pills:$/, {timeout: 10000}, async (name,labels) => { - await monSteps.verifyCheckCardDoesNotHaveLabels(name, labels); -}); - -When(/^click the check card "(.*)" clone button$/, async name => { - await monSteps.clickCheckCardCloneButton(name); -}); - -When(/^click the check card "(.*)" clone confirm button$/, async name => { - await monSteps.clickCheckCardCloneConfirm(name); -}); - -Then(/^the check cards column contains$/, async names => { - await monSteps.verifyCheckCardsVisible(names); -}); - -Then(/^the check cards column does not contain$/, {timeout: 10000}, async names => { - await monSteps.verifyCheckCardsNotPresent(names); -}); - -When(/^enter into the check cards filter field "(.*)"$/, async value => { - await monSteps.enterValueToCheckCardsFilter(value); -}); - -When(/^clear the check cards filter field$/, async () => { - await monSteps.clearCheckCardsFilter(); -}); - -Then(/^the "(.*)" cards column empty state message is "(.*)"$/, async (col, message) => { - await monSteps.verifyEmptyChecksStateMessage(col, message); -}); - -When(/^click open history of the check card "(.*)"$/, async name => { - await monSteps.clickCheckCardOpenHistory(name); -}); - -When(/^click open history confirm of the check card "(.*)"$/, async name => { - await monSteps.clickCheckCardOpenHistoryConfirm(name); -}); - -When(/^click delete of the check card "(.*)"$/, async name => { - await monSteps.clickCheckCardDelete(name); -}); - -When(/^click delete confirm of the check card "(.*)"$/, async name => { - await monSteps.clickCheckCardDeleteConfirm(name); -}); - -Then(/^there is no alert card named "(.*)"$/, async name => { - await monSteps.verifyCheckCardsNotPresent(name); -}); - - diff --git a/e2e/src/step_definitions/onboarding/onboardStepDefs.js b/e2e/src/step_definitions/onboarding/onboardStepDefs.js deleted file mode 100644 index d41e634a69..0000000000 --- a/e2e/src/step_definitions/onboarding/onboardStepDefs.js +++ /dev/null @@ -1,145 +0,0 @@ -import { Given, Then, When } from 'cucumber'; - -const onboardingSteps = require(__srcdir + '/steps/onboarding/onboardingSteps.js'); - -let driver = __wdriver; -let onbSteps = new onboardingSteps(driver); - -Given(/^I open the Influx onboarding page$/, {timeout: 15000}, async () => { - - //await driver.get("http://" + __config.host + ":" + __config.port + "/" ) - await onbSteps.openBase(); - - //await onbSteps.delay(3000) - //return 'pending'; - -}); - -Then(/^there is a Welcome message$/, async () => { - - /* - expect(await driver.findElement(By.css('[data-testid=init-step--head-main]')) - .getText()) - .to - .include('Welcome') */ - await onbSteps.verifyHeadContains('Welcome'); - //return 'pending'; - -}); - -Then(/^there is a link to corporate$/, async () => { - - /* - expect(await driver.findElement(By.css('[data-testid=credits] a')).getText()) - .to - .equal('InfluxData') - - expect(await driver.findElement(By.css('[data-testid=credits] a')).getAttribute('href')) - .to - .equal('https://www.influxdata.com/') - */ - await onbSteps.verifyCreditsLink(); - -}); - -When(/^I click on Get Started$/, async () => { - - //await driver.findElement(By.css('[data-testid=onboarding-get-started]')).click() - //return 'pending'; - await onbSteps.clickStart(); - //await onbSteps.delay(3000) - -}); - -Then(/^the Initial Setup Page is loaded$/, async () => { - /* - expect(await driver.findElement(By.css('[data-testid=admin-step--head-main]')).getText()) - .to - .include('Setup') - - expect(await driver.findElement(By.css('[data-testid=nav-step--welcome]')).getText()) - .to - .equal('Welcome') - - expect(await driver.findElement(By.css('[data-testid=nav-step--setup]')).getText()) - .to - .include('Setup') */ - await onbSteps.verifySetupHeaderContains('Setup'); - await onbSteps.verifyNavCrumbText('welcome', 'Welcome'); - await onbSteps.verifyNavCrumbText('setup', 'Setup'); - //return 'pending'; - -}); - -Then(/^the continue button is disabled$/, async () => { - await onbSteps.verifyContinueButtonDisabled(); -}); - -When(/^enter a new user name "(.*?)"$/, async name => { - await onbSteps.setInputFieldValue('username', (name === 'DEFAULT') ? __defaultUser.username : name); - //return "pending"; -}); - -When(/^enter a new password "(.*?)"$/, async password => { - await onbSteps.setInputFieldValue('password', (password === 'DEFAULT') ? __defaultUser.password : password); - //return "pending"; -}); - -When(/^enter confirm the new password "(.*?)"$/, async password => { - await onbSteps.setInputFieldValue('password-chk', (password === 'DEFAULT') ? __defaultUser.password : password); - //return "pending"; -}); - -Then(/^the form error message says "(.*?)"$/, async message => { - await onbSteps.verifyFormErrorMessage(message); -}); - -Then(/^the form error message is not present$/, async () => { - await onbSteps.verifyFormErrorMessageNotPresent(); -}); - -When(/^enter a new organization name "(.*?)"$/, async orgname => { - await onbSteps.setInputFieldValue('orgname', (orgname === 'DEFAULT') ? __defaultUser.org : orgname); - //return "pending"; -}); - -When(/^enter a new bucket name "(.*?)"$/, async bucketname => { - await onbSteps.setInputFieldValue('bucketname', (bucketname === 'DEFAULT') ? __defaultUser.bucket : bucketname); - //return "pending"; -}); - -When(/^click next from setup page$/, async () => { - await onbSteps.clickContinueButton(); - // return "pending"; -}); - -When(/^click next from setup page without page check$/, async() => { - await onbSteps.clickContinueButton(false); -}); - -Then(/^verify ready page$/, async () => { - await onbSteps.verifySubtitle(); - await onbSteps.verifyNavCrumbText('complete', 'Complete'); - await onbSteps.delay(1000); - //ideally following should be not an exact match but a general value match e.g. lighter than, darker than - //also firefox returns different rgb function signature, so just test for rgb values - await onbSteps.verifyNavCrumbTextColor('complete', '246, 246, 248'); - //return "pending"; - -}); - -When(/^click quick start button$/, {timeout: 10000}, async () => { - //await readyPage.clickQickStart() - await onbSteps.clickQuickStartButton(); - //return 'pending' -}); - -When(/^click advanced button$/, {timeout: 10000}, async () => { - await onbSteps.clickAdvancedButton(); -}); - -Then(/^Fail$/, async() => { - await onbSteps.failTest(); -}); - - diff --git a/e2e/src/step_definitions/organization/organizationStepDefs.js b/e2e/src/step_definitions/organization/organizationStepDefs.js deleted file mode 100644 index f25d7a6958..0000000000 --- a/e2e/src/step_definitions/organization/organizationStepDefs.js +++ /dev/null @@ -1,13 +0,0 @@ -import { Then, When } from 'cucumber'; - -const organizationSteps = require(__srcdir + '/steps/organization/organizationSteps.js'); - - -let orgSteps = new organizationSteps(__wdriver); - - -Then(/^the Organization page is loaded$/, {timeout: 2 * 5000}, async() => { - await orgSteps.isLoaded(); - await orgSteps.verifyIsLoaded(); - await orgSteps.verifyHeaderContains('Organization'); -}); \ No newline at end of file diff --git a/e2e/src/step_definitions/settings/labelsStepDefs.js b/e2e/src/step_definitions/settings/labelsStepDefs.js deleted file mode 100644 index 2b2f7890b9..0000000000 --- a/e2e/src/step_definitions/settings/labelsStepDefs.js +++ /dev/null @@ -1,150 +0,0 @@ -import { Then, When } from 'cucumber'; - -const labelsSteps = require(__srcdir + '/steps/settings/labelsSteps.js'); - -let lblSteps = new labelsSteps(__wdriver); - -Then(/^the create Label popup is loaded$/, {timeout: 10000}, async () => { - await lblSteps.verifyCreateLabelPopupLoaded(); -}); - -When(/^dismiss the Create Label Popup$/, async () => { - await lblSteps.dismissCreateLabelPopup(); -}); - -When(/^cancel the create label popup$/, async () => { - await lblSteps.cancelCreateLabelPopup(); -}); - -When(/^I click the empty state Create Label button$/, async () => { - await lblSteps.clickCreateLabelButtonEmpty(); -}); - -When(/^I click the header Create Label button$/, async () => { - await lblSteps.clickCreateLabelButtonHeader(); -}); - -Then(/^the color input color matches the preview color$/, async () => { - await lblSteps.verifyInputColorMatchesPreview(); -}); - -Then(/^the preview label pill contains "(.*)"$/, async text => { - await lblSteps.verifyCreateLabelPreviewPillText(text); -}); - -When(/^enter the value "(.*)" into the label popup name input$/, async text => { - await lblSteps.typeCreateLabelPopupName(text); -}); - -When(/^enter the value "(.*)" into the label popup description input$/, async descr => { - await lblSteps.typeCreateLabelPopupDescription(descr); -}); - -When(/^clear the label popup name input$/, async () => { - await lblSteps.clearLabelPopupNameInput(); -}); - -When(/^clear the label popup description input$/, async () => { - await lblSteps.clearLabelPopupDescriptionInput(); -}); - -When(/^clear the label popup color input$/, async () => { - await lblSteps.clearLabelPopupColorInput(); -}); - -When(/^enter the value "(.*)" into the label popup color input$/, async value => { - await lblSteps.typeCreateLabelPopupColor(value); -}); - -When(/^click the color select button I'm feeling lucky$/, async () => { - await lblSteps.clickLabelPopupLuckyColor(); -}); - -Then(/^the value in the label popup color input is not "(.*)"$/, async value => { - await lblSteps.verifyLabelPopupColorInputNotValue(value); -}); - -When(/^click the label popup color swatch "(.*)"$/, async name => { - await lblSteps.clickLabelPopupColorSwatch(name); -}); - -Then(/^the value in the label popup color input is "(.*)"$/, async value => { - await lblSteps.verifyLabelPopupColorInputValue(value); -}); - -Then(/^the label popup preview text color is "(.*)"$/, async value => { - await lblSteps.verifyLabelPopupPreviewTextColor(value); -}); - -When(/^set the color in the label popup to "(.*)"$/, async color => { - if(color[0] === '#'){ //string value for color input - await lblSteps.clearLabelPopupColorInput(); - await lblSteps.typeCreateLabelPopupColor(color); - }else{ //swatch name - await lblSteps.clickLabelPopupColorSwatch(color); - } -}); - -When(/^click the label popup Create Label button$/, async () => { - await lblSteps.clickLabelPopupCreateButton(); -}); - -When(/^click the label popup Save Changes button$/, async () => { - await lblSteps.clickLabelPopupCreateButton(); -}); - -Then(/^there is a label card named "(.*)" in the labels list$/, async name => { - await lblSteps.verifyLabelCardInList(name); -}); - -Then(/^the label card "(.*)" has a pill colored "(.*)"$/, async (name, color) => { - await lblSteps.verifyLabelCardPillColor(name, color); -}); - -Then(/^the label card "(.*)" has description "(.*)"$/, async (name, descr) => { - await lblSteps.verifyLabelCardDescription(name, descr); -}); - -When(/^I click the Label Card Pill "(.*)"$/, async name => { - await lblSteps.clickLabelCardPill(name); -}); - -Then(/^the edit label popup is loaded$/, async () => { - await lblSteps.verifyEditLabelPopuLoaded(); -}); - -Then(/^the first labels are sorted as "(.*)"$/, async labels => { - await lblSteps.verifyLabelSortOrder(labels); -}); - -When(/^click sort label by name$/, async () => { - await lblSteps.clickLabelSortByName(); -}); - -When(/^click sort label by description$/, async () => { - await lblSteps.clickLabelSortByDescription(); -}); - -When(/^clear the labels filter input$/, async () => { - await lblSteps.clearLabelFilterInput(); -}); - -When(/^enter the value "(.*)" into the label filter$/, async text => { - await lblSteps.enterTextIntoLabelFilter(text); -}); - -Then(/^the labels "(.*)" are not present$/, {timeout: 15000}, async labels => { - await lblSteps.verifyLabelsNotPresent(labels); -}); - -When(/^hover over label card "(.*)"$/, async name => { - await lblSteps.hoverOverLabelCard(name); -}); - -When(/^click delete for the label card "(.*)"$/, async name => { - await lblSteps.clickLabelCardDelete(name); -}); - -When(/^click delete confirm for the label card "(.*)"$/, async name => { - await lblSteps.clickLabelCardDeleteConfirm(name); -}); diff --git a/e2e/src/step_definitions/settings/settingsStepDefs.js b/e2e/src/step_definitions/settings/settingsStepDefs.js deleted file mode 100644 index 0f138eb9c0..0000000000 --- a/e2e/src/step_definitions/settings/settingsStepDefs.js +++ /dev/null @@ -1,51 +0,0 @@ -import { Then, When } from 'cucumber'; -const settingsSteps = require(__srcdir + '/steps/settings/settingsSteps.js'); -const variablesSteps = require(__srcdir + '/steps/settings/variablesSteps.js'); -const membersSteps = require(__srcdir + '/steps/settings/membersSteps.js'); -const labelsSteps = require(__srcdir + '/steps/settings/labelsSteps.js'); -const tokensSteps = require(__srcdir + '/steps/loadData/tokensSteps.js'); -const orgProfileSteps = require(__srcdir + '/steps/settings/orgProfileSteps.js'); -const templatesSteps = require(__srcdir + '/steps/settings/templatesSteps.js'); - - -let setSteps = new settingsSteps(__wdriver); -let varTabSteps = new variablesSteps(__wdriver); -let memTabSteps = new membersSteps(__wdriver); -let tlateTabSteps = new templatesSteps(__wdriver); -let labTabSteps = new labelsSteps(__wdriver); -let tknTabSteps = new tokensSteps(__wdriver); -let opTabSteps = new orgProfileSteps(__wdriver); - -Then(/^the Settings page is loaded$/, {timeout: 2 * 5000}, async() => { - await setSteps.isLoaded(); - await setSteps.verifyIsLoaded(); - await setSteps.verifyHeaderContains('Settings'); -}); - -When(/^click the settings tab "(.*?)"$/, async(name) => { - await setSteps.clickTab(name); -}); - -Then(/^the variables Tab is loaded$/, {timeout: 2 * 5000}, async() => { - await varTabSteps.isLoaded(); -}); - -Then(/^the templates Tab is loaded$/, {timeout: 2 * 5000}, async() => { - await tlateTabSteps.isLoaded(); -}); - -Then(/^the labels Tab is loaded$/, {timeout: 2 * 5000}, async() => { - await labTabSteps.isLoaded(); -}); - -Then(/^the tokens Tab is loaded$/, {timeout: 2 * 5000}, async() => { - await tknTabSteps.isLoaded(); -}); - -Then(/^the members Tab is loaded$/, {timeout: 2 * 5000}, async() => { - await memTabSteps.isLoaded(); -}); - -Then(/^the org profile Tab is loaded$/, {timeout: 10000}, async() => { - await opTabSteps.isLoaded(); -}); diff --git a/e2e/src/step_definitions/settings/templatesStepDefs.js b/e2e/src/step_definitions/settings/templatesStepDefs.js deleted file mode 100644 index c95f30dc34..0000000000 --- a/e2e/src/step_definitions/settings/templatesStepDefs.js +++ /dev/null @@ -1,112 +0,0 @@ -import { Then, When } from 'cucumber'; - -const templatesSteps = require(__srcdir + '/steps/settings/templatesSteps.js'); - -let tpltSteps = new templatesSteps(__wdriver); - -Then(/^the templates are sorted as:$/, async templates => { - await tpltSteps.verifyTemplateCardsSort(templates); -}); - -When(/^click user templates$/, async () => { - await tpltSteps.clickUserTemplatesButton(); -}); - -When(/^click empty state import template button$/, async () => { - await tpltSteps.clickImportTemplateEmptyButton(); -}); - -Then(/^the import template popup is loaded$/, async () => { - await tpltSteps.verifyImportTemplatePopupLoaded(); -}); - -Then(/^the Import JSON as template button is disabled$/, async () => { - await tpltSteps.verifyImportTemplatePopupSubmitEnabled(false); -}); - -Then(/^the Import JSON as template button is enabled$/, async () => { - await tpltSteps.verifyImportTemplatePopupSubmitEnabled(true); -}); - -When(/^click header import template button$/, async () => { - await tpltSteps.clickImportTemplateHeaderButton(); -}); - -Then(/^click the import template paste button$/, async () => { - await tpltSteps.clickImportTemplatePasteButton(); -}); - -Then(/^the Import Template file upload area is present$/, async () => { - await tpltSteps.verifyImportTemplateFileUpload(true); -}); - -Then(/^the Import Template file upload area is not present$/, async () => { - await tpltSteps.verifyImportTemplateFileUpload(false); -}); - -Then(/^the Import Template paste JSON text area is present$/, async () => { - await tpltSteps.verifyImportTemplatePasteJSON(true); -}); - -Then(/^the Import Template paste JSON text area is not present$/, async () => { - await tpltSteps.verifyImportTemplatePasteJSON(false); -}); - -When(/^enter into the Impprt Template paste JSON text area:$/, async text => { - await tpltSteps.enterTextImportTemplateJSON(text); -}); - -When(/^click the import template upload button$/, async () => { - await tpltSteps.clickImportTemplateUploadButton(); -}); - -When(/^upload the template file "(.*)"$/, async filePath => { - await tpltSteps.uploadTemplateFile(filePath); -}); - -When(/^click import template popup submit button$/, async () => { - await tpltSteps.clickImportTemplateSubmitButton(); -}); - -Then(/^there is a template card named "(.*)"$/, async name => { - await tpltSteps.verifyTemplateCardVisibility(name); -}); - -When(/^paste contents of "(.*)" to template textarea$/, {timeout: 60000 }, async filepath => { - await tpltSteps.copyFileContentsToTemplateTextare(filepath); -}); - -Then(/^a REST template document for user "(.*)" titled "(.*)" exists$/, async (user,title) => { - await tpltSteps.verifyRESTTemplateDocumentExists(user ,title); -}); - -When(/^enter the value "(.*)" into the templates filter field$/, async value => { - await tpltSteps.enterTemplatesFilterValue(value); -}); - -Then(/^the template cards "(.*)" are not present$/, {timeout: 30000}, async templates => { - let tempArr = templates.split(','); - for(let i = 0; i < tempArr.length; i++){ - await tpltSteps.verifyTemplateNotPresent(tempArr[i]); - } -}); - -When(/^clear the templates filter$/, async () => { - await tpltSteps.clearTemplatesFilter(); -}); - -When(/^click templates sort by Name$/, async () => { - await tpltSteps.clickSortTemplatesByName(); -}); - -When(/^hover over template card named "(.*)"$/, async name => { - await tpltSteps.hoverOverTemplateCard(name); -}); - -When(/^click the context delete button of template "(.*)"$/, async name => { - await tpltSteps.clickTemplateContextDelete(name); -}); - -When(/^click the delete confirm button of template "(.*)"$/, async name => { - await tpltSteps.clickTemplateDeleteConfirm(name); -}); diff --git a/e2e/src/step_definitions/settings/variablesStepDefs.js b/e2e/src/step_definitions/settings/variablesStepDefs.js deleted file mode 100644 index fbbba179a2..0000000000 --- a/e2e/src/step_definitions/settings/variablesStepDefs.js +++ /dev/null @@ -1,298 +0,0 @@ -import { Then, When } from 'cucumber'; - -const variablesSteps = require(__srcdir + '/steps/settings/variablesSteps.js'); - -let vblSteps = new variablesSteps(__wdriver); - -When(/^click create variable dropdown in header$/, async () => { - await vblSteps.clickCreateVariableDropdown(); -}); - -When(/^click create variable dropdown empty$/, async () => { - await vblSteps.clickCreateVariableDropdownEmpty(); -}); - -Then(/^the import variable popup is loaded$/, async () => { - await vblSteps.verifyImportVariablePopupLoaded(); -}); - -When(/^click "(.*)" variable dropdown item$/, async item => { - await vblSteps.clickCreateVariableDropdownItem(item); -}); - -Then(/^the create variable popup is loaded$/, async () => { - await vblSteps.verifyCreateVariablePopupLoaded(); -}); - -Then(/^the Import Variable JSON textarea is visible$/, async () => { - await vblSteps.verifyImportPopupJSONTextareaVisible(true); -}); - -When(/^click the Import Variable popup paste JSON button$/, async () => { - await vblSteps.clickImportPopupPasteJSON(); -}); - -Then(/^the Import JSON as variable button is enabled$/, async () => { - await vblSteps.verifyImportPopupImportJSONButtonEnabled(true); -}); - -When(/^click the Import Variable popup Upload File button$/, async() => { - await vblSteps.clickImportPopupUploadFile(); -}); - -Then(/^the Import Variable JSON textarea is not visible$/, async() => { - await vblSteps.verifyImportPopupJSONTextareaVisible(false); -}); - -Then(/^the Import JSON as variable button is not enabled$/, async() => { - await vblSteps.verifyImportPopupImportJSONButtonEnabled(false); -}); - -Then(/^the Import JSON file upload area is present$/, async () => { - await vblSteps.verifyImportPopupFileUploadPresent(); -}); - -Then(/^the create variable popup selected type is "(.*)"$/, async type => { - await vblSteps.verifyCreateVarPopupSelectedType(type); -}); - -Then(/^the create variable popup create button is disabled$/, async () => { - await vblSteps.verifyCreatePopupCreateEnabled(false); -}); - -Then(/^the create variable popup script editor is visible$/, async () => { - await vblSteps.verifyCreateVarPopupQueryEditorVisible(true); -}); - -Then(/^the create variable popup script editor is not visible$/, async () => { - await vblSteps.verifyCreateVarPopupQueryEditorVisible(false); -}); - -When(/^click the create variable popup type dropdown$/, async () => { - await vblSteps.clickCreateVariableTypeDropdown(); -}); - -When(/^click the edit variable popup type dropdown$/, async () => { - await vblSteps.clickEditVariableTypeDropdown(); -}); - -Then(/^the create variable popup textarea is visible$/, async () => { - await vblSteps.verifyCreateVarPopupTextareaVisible(true); -}); - -Then(/^the create variable popup default value dropdown is visible$/, async () => { - await vblSteps.verifyCreateVarPopupDefaultValDropdownVisible(true); -}); - -Then(/^the create variable popup info line contains "(.*)" items$/, async count => { - await vblSteps.verifyCreateVarPopupInfoCount(count); -}); - -Then(/^the create variable popup textarea is not visible$/, async () => { - await vblSteps.verifyCreateVarPopupTextareaVisible(false); -}); - -Then(/^the create variable popup default value dropdown is not visible$/, async () => { - await vblSteps.verifyCreateVarPopupDefaultValDropdownVisible(false); -}); - -When(/^click the create variable popup type dropdown item "(.*)"$/, async item => { - await vblSteps.clickCreateVarPopupTypeDropdownItem(item); -}); - -When(/^click the edit variable popup type dropdown item "(.*)"$/, async item => { - await vblSteps.clickEditVarPopupTypeDropdownItem(item); -}); - -Then(/^the create variable popup info line is not visible$/, async () => { - await vblSteps.verifyCreateVarPopupInfoVisible(false); -}); - -When(/^upload the import variable file "(.*)"$/, async path2file => { - await vblSteps.uploadImportVarPopupFile(path2file); -}); - -Then(/^the import variable drag and drop header contains success "(.*)"$/, async path2file => { - await vblSteps.verifyImportPopupUploadSuccess(); - await vblSteps.verifyImportPopupUploadFilename(path2file); -}); - -When(/^click the import variable import button$/, async () => { - await vblSteps.clickImportPopupImportButton(); -}); - -Then(/^there is a variable card for "(.*)"$/, async name => { - await vblSteps.verifyVariableCardVisible(name); -}); - -When(/^enter the create variable popup name "(.*)"$/, async name => { - await vblSteps.enterCreateVarPopupName(name); -}); - -When(/^enter the edit variable popup name "(.*)"$/, async name => { - await vblSteps.enterCreateVarPopupName(name); -}); - -When(/^clear the create variable popup name input$/, async () => { - await vblSteps.clearCreateVarPopupName(); -}); - -When(/^clear the edit variable popup name input$/, async () => { - await vblSteps.clearCreateVarPopupName(); -}); - -When(/^enter the create variable popup values:$/, async values => { - await vblSteps.enterCreateVarPopupTextarea(values); -}); - -When(/^enter the edit variable popup values:$/, async values => { - await vblSteps.enterCreateVarPopupTextarea(values); -}); - -When(/^enter the create variable popup CodeMirror text:$/, async text => { - await vblSteps.setVariablePopupCodeMirrorText(text); -}); - -When(/^enter the create variable popup Monaco Editor text:$/, {timeout: 10000}, async text => { - await vblSteps.setVariablePopupMonacoEditText(text); -}); - -When(/^enter the edit variable popup Query text:$/, async text => { - await vblSteps.setVariablePopupMonacoEditText(text); -}); - -When(/^click the create variable popup title$/, async () => { - await vblSteps.clickPopupTitle(); -}); - -When(/^click the edit variable popup title$/, async () => { - await vblSteps.clickPopupTitle(); -}); - -Then(/^the selected default variable dropdown item is "(.*)"$/, async item => { - await vblSteps.verifyCreatePopupDefaultValDropdownSelected(item); -}); - -When(/^click the create variable popup default dropdown$/, async () => { - await vblSteps.clickCreateVarPopupDefaultDropdown(); -}); - -When(/^click the edit variable popup default dropdown$/, async () => { - await vblSteps.clickCreateVarPopupDefaultDropdown(); -}); - -When(/^click the create variable popup default dropdown item "(.*)"$/, async item => { - await vblSteps.clickCreateVarPopupDefaultDropdownItem(item); -}); - -When(/^enter the value "(.*)" into the variables filter$/, async value => { - await vblSteps.enterValueIntoVariablesFilter(value); -}); - -Then(/^the variable cards "(.*)" are visible$/, async cards => { - await vblSteps.verifyVariableCardsVisible(cards); -}); - -When(/^click the create variable popup default csv dropdown item "(.*)"$/, async item => { - await vblSteps.clickCreatVarPopupDefaultCSVDropdownItem(item); -}); - -When(/^click the edit variable popup default csv dropdown item "(.*)"$/, async item => { - await vblSteps.clickCreatVarPopupDefaultCSVDropdownItem(item); -}); - -When(/^click the create variable popup create button$/, async () => { - await vblSteps.clickCreateVarPopupCreateButton(); -}); - -When(/^click the edit variable popup submit button$/, async ()=> { - await vblSteps.clickEditVarPopupSubmitButton(); -}); - -Then(/^the variable cards "(.*)" are not present$/, {timeout: 30000}, async cards => { - await vblSteps.verifyVariablsCardsNotPresent(cards); -}); - -Then(/^the variable cards are sorted as "(.*)"$/, async cards => { - await vblSteps.verifyVariableCardsSort(cards); -}); - -When(/^click the variable sort by name button$/, async () => { - await vblSteps.clickVariableSortByName(); -}); - -When(/^clear the variables filter$/, async () => { - await vblSteps.clearVariablesFilter(); -}); - -When(/^click the variable card name "(.*)"$/, async name => { - await vblSteps.clickVariableCardName(name); -}); - -Then(/^the edit variable popup is loaded$/, async () => { - await vblSteps.verifyEditVariablePopupLoaded(); -}); - -When(/^hover over variable card named "(.*)"$/, async name => { - await vblSteps.hoverOverVariableCard(name); -}); - -When(/^click the context menu of the variable "(.*)"$/, async name => { - await vblSteps.clickVariableCardContextMenu(name); -}); - -When(/^click the context menu item "(.*)" of the variable "(.*)"$/, {timeout: 10000}, async (item, name) => { - await vblSteps.clickVariableCardContextMenuItem(name,item); -}); - -Then(/^the variable name warning popup is visible$/, async () => { - await vblSteps.verifyVariableNameChangeWarningPopupLoaded(); -}); - -When(/^click the rename variable warning popup understand button$/, async () => { - await vblSteps.clickVariableNameChangeWarningUnderstand(); -}); - -When(/^clear the rename variable popup name input$/, async () => { - await vblSteps.clearVariableNameChangeNameInput(); -}); - -Then(/^the rename variable form warning states "(.*)"$/, async msg => { - await vblSteps.verifyFormErrorMessageContains(msg); -}); - -Then(/^the rename variable from warning icon is visible$/, async () => { - await vblSteps.verifyInputErrorIcon(); -}); - -Then(/^the rename variable submit button is disabled$/, async () => { - await vblSteps.verifyChangeVariableNameSubmitDisabled(); -}); - -When(/^enter the new variable name "(.*)"$/, async name => { - await vblSteps.enterNewVariableName(name); -}); - -When(/^click rename variable popup submit button$/, async () => { - await vblSteps.clickSubmitRenameVariablePopup(); -}); - -Then(/^the edit variable name input is disabled$/, async () => { - await vblSteps.verifyEditVariablePopupNameDisabled(); -}); - -Then(/^the edit variable popup textarea is cleared$/, async () => { - await vblSteps.verifyEditVariablePopupTextareaCleared(); -}); - -When(/^click delete menu of variable card named "(.*)"$/, async name => { - await vblSteps.clickVariableCardDelete(name); -}); - -When(/^click delete confirm of variable card named "(.*)"$/, async name => { - await vblSteps.clickVariableCardDeleteConfirm(name); -}); - -Then(/^the variable card "(.*)" is not present$/, async name => { - await vblSteps.verifyVariableCardNotPresent(name); -}); diff --git a/e2e/src/step_definitions/signin/signinStepDefs.js b/e2e/src/step_definitions/signin/signinStepDefs.js deleted file mode 100644 index 588b5174c3..0000000000 --- a/e2e/src/step_definitions/signin/signinStepDefs.js +++ /dev/null @@ -1,42 +0,0 @@ -import { Then, When } from 'cucumber'; -const signinSteps = require(__srcdir + '/steps/signin/signinSteps.js'); - -let sSteps = new signinSteps(__wdriver); - -When(/^open the signin page$/, {timeout: 15000}, async () => { - await sSteps.openContext(sSteps.signinPage.urlCtx); -}); - -Then(/^the sign in page is loaded$/, async () => { - await sSteps.verifyIsLoaded(); -}); - -Then(/^the heading contains "(.*?)"$/, async text => { - await sSteps.verifyHeadingContains(text); -}); - -Then(/^the InfluxData heading is visible$/, async () => { - await sSteps.verifyHeading(); -}); - -Then(/^the version shown contains "(.*?)"$/, async version => { - await sSteps.verifyVersionContains((version == 'DEFAULT') ? __config.influxdb.version : version); -}); - -Then(/^the credits are valid$/, async () => { - await sSteps.verifyCreditsLink(); -}); - -When(/^enter the username "(.*?)"$/, async name => { - await sSteps.enterUsername((name === 'DEFAULT') ? __defaultUser.username : name); -}); - -When(/^enter the password "(.*?)"$/, async password => { - await sSteps.enterPassword((password === 'DEFAULT') ? __defaultUser.password : password); -}); - -When(/^click the signin button$/, async () => { - await sSteps.clickSigninButton(); - await sSteps.driver.sleep(3000); -}); - diff --git a/e2e/src/step_definitions/tasks/tasksStepDefs.js b/e2e/src/step_definitions/tasks/tasksStepDefs.js deleted file mode 100644 index 1aea42e05d..0000000000 --- a/e2e/src/step_definitions/tasks/tasksStepDefs.js +++ /dev/null @@ -1,14 +0,0 @@ -import { Then } from 'cucumber'; -const tasksSteps = require(__srcdir + '/steps/tasks/tasksSteps.js'); - -let tSteps = new tasksSteps(__wdriver); - -Then(/^the Tasks page is loaded$/, {timeout: 2 * 5000}, async() => { - await tSteps.isLoaded(); - await tSteps.verifyIsLoaded(); - await tSteps.verifyHeaderContains('Tasks', 'tasks-page'); -}); - -Then(/^there is a task named "(.*)"$/, async name =>{ - await tSteps.verifyTaskCardVisible(name); -}); diff --git a/e2e/src/steps/baseSteps.js b/e2e/src/steps/baseSteps.js deleted file mode 100644 index e30e20ecb3..0000000000 --- a/e2e/src/steps/baseSteps.js +++ /dev/null @@ -1,862 +0,0 @@ -const fs = require('fs'); -const chai = require('chai'); -chai.use(require('chai-match')); - -const expect = require('chai').expect; -const assert = require('chai').assert; - -const { By, Key, until, logging } = require('selenium-webdriver'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -const basePage = require (__srcdir + '/pages/basePage.js'); - -const keyMap = {'enter': Key.ENTER, - 'tab': Key.TAB, - 'backspace': Key.BACK_SPACE, - 'bksp': Key.BACK_SPACE, - 'space': Key.SPACE, - 'escape': Key.ESCAPE, - 'esc': Key.ESCAPE, - 'ctrl': Key.CONTROL, - 'end': Key.END, - 'shift': Key.SHIFT, - 'del': Key.DELETE, - 'alft': Key.ARROW_LEFT, - 'arght': Key.ARROW_RIGHT, - 'aup': Key.ARROW_UP, - 'adown': Key.ARROW_DOWN -}; - - -class baseSteps{ - constructor(driver){ - this.driver = driver; - this.basePage = new basePage(driver); - } - - async delay(timeout){ - await this.driver.sleep(timeout); - } - - async resetEnvironment(){ - switch(__config.deployment.toUpperCase()){ - case 'CLOUD': - if(!__reportedResetOnce) console.log("---- TODO Resetting against cloud -----"); - break; - case 'NIGHTLY_DOCKER': - if(!__reportedResetOnce) console.log("----- Resetting against nightly docker -----"); - await influxUtils.flush(); - break; - case 'LOCAL_BUILD': - if(!__reportedResetOnce) console.log("---- TODO Resetting against local build -----"); - //todo review if works against local build - await influxUtils.flush(); - break; - } - } - - async clearBrowserLocalStorage(){ - await this.driver.executeScript('window.localStorage.clear()'); - } - - async openBase(){ - await this.driver.get( __config.influx_url); - await this.driver.wait(function(driver = this.driver) { - return driver.executeScript('return document.readyState').then(function(readyState) { - return readyState === 'complete'; - }); - }); - - } - - async openContext(ctx){ - await this.driver.get( `${__config.influx_url}/` + ctx); - await this.driver.wait(function(driver = this.driver) { - return driver.executeScript('return document.readyState').then(function(readyState) { - return readyState === 'complete'; - }); - }); - } - - async waitForPageLoad(){ - await this.driver.wait(function(driver = this.driver) { - return driver.executeScript('return document.readyState').then(function(readyState) { - return readyState === 'complete'; - }); - }); - } - - async isNotificationMessage(message){ - //wait a second for all notifications to load - await this.driver.sleep(1000); - - await this.basePage.getNoficicationSuccessMsgs().then(async elems => { - let match = false; - - for(var i = 0; i < elems.length; i++){ - if(await elems[i].getText() === message){ - match = true; - break; - } - } - - assert(match, `Failed to find "${message}" in notifications`); - }); - } - - async containsNotificationText(text){ - await this.basePage.getNoficicationSuccessMsgs().then(async elems => { - let match = false; - - for(var i = 0; i < elems.length; i++){ - if((await elems[i].getText()).includes(text)){ - match = true; - break; - } - } - - assert(match, `Failed to find notification containing "${text}"`); - }); - } - - async containsPrimaryNotificationText(text){ - await this.basePage.getNotificationPrimaryMsgs().then(async elems => { - let match = false; - - for(var i = 0; i < elems.length; i++){ - if((await elems[i].getText()).includes(text)){ - match = true; - break; - } - } - - assert(match, `Failed to find notification containing "${text}"`); - }); - } - - async containsErrorNotificationText(text){ - await this.basePage.getNotificationErrorMsgs().then(async elems => { - let match = false; - - for(var i = 0; i < elems.length; i++){ - if((await elems[i].getText()).includes(text)){ - match = true; - break; - } - } - - assert(match, `Failed to find error notification containing "${text}"`); - }); - } - - async closeAllNotifications(){ - await this.driver.sleep(500); //might not be loaded - todo better wait - await this.basePage.getNotificationCloseButtons().then(async btns => { - await btns.forEach(async(btn) => { - await btn.click().catch(async e => { - //Ignore StaleElements - message likely already closed itself - if(e.name !== 'StaleElementReferenceError'){ - throw e; - } - }); - }); - }); - await this.driver.sleep(500); //make sure are closed - todo better wait - - } - - async hoverOver(element){ - let actions = await this.driver.actions({bridge: true}); - await actions.move({origin: element}).perform().then(async () => { - // console.log("DEBUG hover success "); - // await this.driver.sleep(1000) - //console.log("SUCCESS " + resp) - }).catch( err => { - console.log('ERR ' + err); - throw(err); // rethrow to cucumber - else error not flagged and step is success - }); - } - - async verifyElementErrorMessage(msg, equal = true){ - await this.basePage.getPopupFormElementError().then(async elem => { - await elem.getText().then(async elText => { - if(equal) { - expect(elText).to.equal(msg); - }else{ - expect(elText).to.include(msg); - } - }); - }); - } - - async verifyNoElementErrorMessage(){ - await this.assertNotPresent(basePage.getPopupFormElementErrorSelector()); - } - - async verifyInputErrorIcon(){ - await this.basePage.getFormInputErrors(async elems => { - expect(elems.length).to.be.above(0); - }); - } - - async verifyNoFormInputErrorIcon(){ - await this.assertNotPresent(basePage.getFormInputErrorSelector()); - } - - async assertVisible(element){ - try { - await expect(await element.isDisplayed()).to.equal(true); - }catch(err){ - console.log('Assert Visible failed: ' + err + '/n waiting for ' + JSON.stringify(element)); - throw err; - } - } - - async assertNotVisible(element){ - await expect(await element.isDisplayed()).to.equal(false); - //await expect(await element.isDisplayed().catch(async err => { console.log("DEBUG err " + err); throw err;})).to.equal(false).catch( async err => { - // console.log("assertNotVisible Error: " + await element.getCssValue()) - // throw(err); - //}); - } - - //selector type should be {type, selector} - async assertNotPresent(selector){ - switch(selector.type){ - case 'css': - await this.driver.findElements(By.css(selector.selector)).then(async elems => { - await expect(elems.length).to.equal(0); - }).catch(async err => { - err += ' expected ' + JSON.stringify(selector) + ' to not be present'; - throw err; - }); - break; - case 'xpath': - await this.driver.findElements(By.xpath(selector.selector)).then(async elems => { - await expect(elems.length).to.equal(0); - }).catch(async err => { - err.message += ' expected ' + selector + ' to not be present'; - throw err; - }); - break; - default: - throw `Unknown selector type ${selector}`; - } - } - - async assertPresent(selector){ - switch(selector.type){ - case 'css': - await this.driver.findElements(By.css(selector.selector)).then(async elems => { - await expect(elems.length).to.be.above(0); - }).catch(async err => { - err += ' expected ' + JSON.stringify(selector) + ' to not be present'; - throw err; - }); - break; - case 'xpath': - await this.driver.findElements(By.xpath(selector.selector)).then(async elems => { - await expect(elems.length).to.be.above(0); - }).catch(async err => { - err.message += ' expected ' + selector + ' to not be present'; - throw err; - }); - break; - default: - throw `Unknown selector type ${selector}`; - } - } - - async isPresent(selector){ - switch(selector.type){ - case 'css': - return await this.driver.findElements(By.css(selector.selector)).then(async elems => { - return elems.length > 0; - }).catch(async err => { - err += ' expected ' + JSON.stringify(selector) + ' to not be present'; - throw err; - }); - case 'xpath': - return await this.driver.findElements(By.xpath(selector.selector)).then(async elems => { - return elems.length > 0; - }).catch(async err => { - err.message += ' expected ' + selector + ' to not be present'; - throw err; - }); - default: - throw `Unknown selector type ${selector}`; - } - } - - //Example def { "points": 20, "field": "level", "measurement": "hydro", "start": "-60h", "vals": "skip", "rows": ["1","-1"] } - async verifyBucketContainsByDef(bucketName, userName, def){ - - let user = influxUtils.getUser(userName); - - let bucket = (bucketName === 'DEFAULT') ? user.bucket : bucketName; - - let define = JSON.parse(def); - - - let query = `from(bucket: "${bucket}") - |> range(start: ${define.start}) - |> filter(fn: (r) => r._measurement == "${define.measurement}") - |> filter(fn: (r) => r._field == "${define.field}")`; - - let results = await influxUtils.query(userName, query); - - for(let i = 0; i < define.rows.length; i++){ - let recs; - if(parseInt(define.rows[i]) === -1){ // last record - recs = results[results.length - 1]; - }else{ //by normal index {0,1,2...N} - recs = results[parseInt(define.rows[i])]; - } - - expect(recs['_field']).to.equal(define.field); - expect(recs['_measurement']).to.equal(define.measurement); - - if(typeof(define.vals) !== 'string'){ - expect(recs['_value']).to.equal(define.vals[i]); - } - - } - } - - async clickPopupWizardContinue(){ - await this.basePage.getPopupWizardContinue().then(async button => { - await button.click().then(async () => { - // await this.driver.wait( // this wait is not consistent - // await this.basePage.getUntilElementNotPresent( - //basePage.getPopupWizardContinueSlector())) // - await this.driver.sleep(500); // todo better wait - }); - }); - } - - async clickPopupWizardPrevious(){ - await this.clickAndWait(await this.basePage.getPopupWizardBack()); // todo better wait - } - - async clickPopupWizardFinish(){ - await this.clickAndWait(await this.basePage.getPopupWizardContinue()); //todo better wait - } - - async dismissPopup(){ - await this.basePage.getPopupDismiss().then(async button => { - await button.click().then(async () => { - await this.driver.sleep(1000); // todo better wait - sometimes can be slow to unload - }); - }); - } - - async clickPopupCancelBtn(){ - await this.clickAndWait(await this.basePage.getPopupCancel()); // todo better wait - } - - async clickPopupCancelBtnSimple(){ - await this.clickAndWait(await this.basePage.getPopupCancelSimple(), async () => { - try { - await this.driver.wait(until.stalenessOf(await this.basePage.getPopupOverlay())); - }catch(err){ - // console.log("DEBUG err " + JSON.stringify(err)); - if(err.name !== 'NoSuchElementError'){ // O.K. if not found - DOM already updated - throw err; - } - } - }); //todo better wait - try until overlay disappear - } - - //sometimes need to lose focus from a popup element to trigger change - async clickPopupTitle(){ - await this.clickAndWait(await this.basePage.getPopupTitle()); - } - - async verifyPopupNotPresent(){ - await this.assertNotPresent(await basePage.getPopupOverlayContainerSelector()); - } - - - /* - Since not currently refining waits - and focusing on velocity of adding new tests - use this - for simple situations - */ - async clickAndWait(element, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); }){ //wait 1/10th implicit timeout - //console.log("DEBUG timeout " + ((await this.driver.manage().getTimeouts()).implicit/20)); - await element.click().then(async () => { - await wait(); - }); - } - - async clickRAndWait(element, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); }) { //wait 1/10th implicit timeout - //console.log("DEBUG timeout " + ((await this.driver.manage().getTimeouts()).implicit/20)); - let action = this.driver.actions(); - await action.contextClick(element).perform().then(async () => { - await wait(); - }); - //await element.click().then(async () => { - // await wait(); - //}); - } - - async typeTextAndWait(input, text, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); }) { //wait 1/10th implicit timeout) - - await input.sendKeys(text).then(async() => { - await wait(); - }); - } - - //Sometimes - rare times - sendKeys in typeTextAndWait() above seems to drop a char - //Use this as a work around - async typeTextParanoAndWait(input, text, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); }){ - - let chars = text.split(''); - - for(let c of chars){ - await input.sendKeys(c).then(async () => { - this.driver.sleep(167) - }) - } - await wait(); - } - - - async verifyElementText(element, text){ - await element.getText().then(async elText => { - await expect(elText).to.equal(text); - }); - } - - async verifyElementContainsText(element, text){ - await element.getText().then(async elText => { - await expect(elText).to.include(text); - }); - } - - async verifyElementContainsClass(element, clazz){ - await element.getAttribute('class').then(async elClass => { - await expect(elClass).to.include(clazz); - }); - } - - async verifyElementDoesNotContainClass(element, clazz){ - await element.getAttribute('class').then(async elClass => { - await expect(elClass).to.not.include(clazz); - }); - } - - async verifyElementDisabled(element){ - await element.getAttribute('disabled').then(async elAttr => { - await expect(elAttr).to.not.be.null; - }); - } - - async verifyElementEnabled(element){ - await element.getAttribute('disabled').then(async elAttr => { - await expect(elAttr).to.be.null; - }); - } - - async verifyWizardContinueButtonDisabled(){ - await this.verifyElementDisabled(await this.basePage.getPopupWizardContinue()); - } - - async verifyWizardDocsLinkURL(url){ - await this.basePage.getPopupWizardDocsLink().then(async elem => { - await elem.getAttribute('href').then(async href => { - await expect(href).to.equal(url); - }); - }); - } - - async clearInputText(input){ - await input.sendKeys(Key.END); - while((await input.getAttribute('value')).length > 0){ - await input.sendKeys(Key.BACK_SPACE); - } - await this.driver.sleep(200); - } - - async verifyPopupAlertContainsText(text){ - await this.basePage.getPopupAlert().then(async elem => { - await elem.findElement(By.css( '[class*=contents]')).then(async contentEl => { - await contentEl.getText().then(async elText => { - await expect(elText).to.include(text); - }); - }); - }); - } - - async verifyPopupAlertMatchesRegex(regex){ - await this.basePage.getPopupAlert().then(async elem => { - await elem.findElement(By.css( '[class*=contents]')).then(async contentEl => { - await contentEl.getText().then(async elText => { - await expect(elText).to.match(regex); - }); - }); - }); - } - - async verifyInputEqualsValue(input, value){ - await input.getAttribute('value').then( async elVal => { - await expect(elVal).to.equal(value); - }); - } - - async verifyInputContainsValue(input, value){ - await input.getAttribute('value').then( async elVal => { - await expect(elVal).to.include(value); - }); - } - - async verifyInputDoesNotContainValue(input, value){ - await input.getAttribute('value').then( async elVal => { - await expect(elVal).to.not.equal(value); - }); - } - - //cmElem will be element containing class .CodeMirror - async setCodeMirrorText(cmElem, text){ - //need to escape new lines which break the js code - text = text.replace(/\n/g, '\\n'); - await this.driver.executeScript(`arguments[0].CodeMirror.setValue("${text}");`, cmElem); - await this.driver.sleep(1000); //todo better wait - troubleshoot flakey consequences of this step - } - - //get text - //window.editor.getModel().getValueInRange(window.editor.getSelection()) - // - // - - async setMonacoEditorText(monElem, text){ - //need to escape new lines which break the js code - //text = text.replace(/\n/g, '\\n'); - //await this.driver.executeScript(`arguments[0].getModel().applyEdits([{ range monaco.Range.fromPositions(arguments[0].getPosition()), text: "${text}"}]);`, monElem); - //await monElem.sendKeys(text); - //let elem = await this.driver.findElement(By.css('.inputarea')); - await monElem.click(); - await monElem.clear(); - await monElem.sendKeys(text); - //await this.driver.executeScript(`arguments[0].setValue('HELLO')`, monElem); - let leadParas = (text.match(/\(/g) || []).length; - for(let i = 0; i < leadParas; i++){ - await monElem.sendKeys(Key.DELETE); //clean up autocomplete close paras TODO - fixme - find better solution - } - - await this.driver.sleep(1000); //todo better wait - troubleshoot flakey consequences of this step - } - - async clearMonacoEditorText(monElem){ - let elem = this.driver.findElement(By.css('.lines-content')); - let text = await elem.getText(); - //await console.log("DEBUG text from monacoElement #" + text + "#"); - await monElem.sendKeys(Key.chord(Key.CONTROL, Key.END)); - for( let i = 0; i < (text.length + 1); i++){ - await monElem.sendKeys(Key.BACK_SPACE); - } - } - - async sendMonacoEditorKeys(monElem, keys){ - let actionList = keys.split(','); - for(let i = 0; i < actionList.length; i++){ - if(actionList[i].includes('+')){ //is chord - let chord = actionList[i].split('+'); - if(chord.length === 2){ - await monElem.sendKeys(Key.chord(keyMap[chord[0].toLowerCase()], - keyMap[chord[1].toLowerCase()])); - }else if(chord.length === 3){ - await monElem.sendKeys(Key.chord(keyMap[chord[0].toLowerCase()], - keyMap[chord[1].toLowerCase()], - keyMap[chord[2].toLowerCase()])); - - }else{ - throw `unsupported chord count ${actionList[i]}`; - } - - }else{ - await monElem.sendKeys(keyMap[actionList[i].toLowerCase()]); - } - } - } - - async getMonacoEditorText(){ - return await this.driver.executeScript('return this.monaco.editor.getModels()[0].getValue()'); - } - - async getCodeMirrorText(cmElem){ - return await this.driver.executeScript('return arguments[0].CodeMirror.getValue()', cmElem); - } - - async verifyFormErrorMessageContains(msg){ - await this.verifyElementContainsText(await this.basePage.getPopupFormElementMessage(), msg); - } - - async verifySubmitDisabled(){ - await this.verifyElementDisabled(await this.basePage.getPopupSubmit()); - } - - async clickPopupSubmitButton(){ - await this.clickAndWait(await this.basePage.getPopupSubmit()); - } - - async verifyElementContainsAttribute(elem, attrib){ - await elem.getAttribute(attrib).then(async val => { - await expect(val).to.exist; - }); - } - - async verifyElementAttributeContainsText(elem,attrib,text){ - await elem.getAttribute(attrib).then(async at => { - await expect(at).to.include(text); - }); - } - - async verifyElementContainsNoText(elem){ - await elem.getText().then(async text => { - await expect(text.length).to.equal(0); - }); - } - - async setFileUpload(filePath){ - await fs.readdir('etc/test-data', function(err, items){ - console.log("DEBUG etc/test-data: \n" + items); - }); - await this.basePage.getPopupFileUpload().then(async elem => { - await elem.sendKeys(process.cwd() + '/' + filePath).then(async () => { - await this.delay(200); //debug wait - todo better wait - }); - }); - } - - async verifyPopupWizardStepStateText(text){ - await this.verifyElementContainsText(await this.basePage.getPopupWizardStepStateText(), text); - } - - async verifyPopupWizardStepState(state){ - await this.verifyElementContainsClass(await this.basePage.getPopupWizardStepStateText(), state); - } - - async verifyPopupFileUploadHeaderText(text){ - await this.verifyElementContainsText(await this.basePage.getPopupFileUploadHeader(), text); - } - - async clickPageTitle(){ - await this.clickAndWait(await this.basePage.getPageTitle()); - } - - async copyFileContentsToTextarea(filepath, textarea){ - let buffer = await influxUtils.readFileToBuffer(process.cwd() + '/' + filepath); - await textarea.sendKeys(buffer); - } - - async pressKeyAndWait(key, wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); }){ - await this.driver.switchTo().activeElement().then(async elem => { - await elem.sendKeys(keyMap[key.toLowerCase()]).then(async () => { - await wait(); - }); - }); - } - - async verifyFileExists(filePath){ - if(__config.sel_docker){ - console.warn('File export not supported without shared memory'); - return; - } - await expect(await influxUtils.fileExists(filePath)).to.be.true; - } - - async verifyDownloadFileMatchingRegexExists(regex){ - let res = await influxUtils.verifyDownloadFileMatchingRegexFilesExist(regex); - await expect(res).to.be.true; - } - - async verifyFirstCSVFileMatching(path, dataDescr){ - let deck = [0,1,2,3,4,5,6,7,8,9]; - //shuffle deck - for(let i = 0; i < deck.length; i++){ - let target = Math.floor(Math.random() * Math.floor(deck.length - 1)); - //swap - let temp = deck[i]; - deck[i] = deck[target]; - deck[target] = temp; - } - - let file = await influxUtils.getNthFileFromRegex(path, 1); - let content = await influxUtils.readFileToBuffer(file); - let firstLF = content.indexOf('\n'); - let firstLine = content.slice(0,firstLF); - - assert.match(firstLine.trim(),/^#group,.*$/); - - let csvContent = await influxUtils.readCSV(content); - - for(let i = 0; i < 3; i++) { - Object.keys(dataDescr).forEach(async (key) => { - - if (dataDescr[key].includes("type:")) { //then just test type - let testType = dataDescr[key].split(':')[1]; - switch (testType) { - case 'double': - case 'float': - case 'number': - await assert.match(csvContent[deck[i]][key], /^[-+]?\d*\.?\d*$/, `${key} should be of type double/float/number`); - break; - case 'date': - //2020-02-27T13:51:09.7Z - await assert.match(csvContent[deck[i]][key], /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.?\d{0,3}Z$/, - `${key} should be of type date`); - break; - default: - throw `unhandled test type ${testType}`; - } - } else { - expect(dataDescr[key].trim()).to.equal(csvContent[deck[i]][key].trim()); - } - }) - } - } - - async scrollElementIntoView(elem){ - await this.assertVisible(elem).catch(async () => { - await this.driver.executeScript('arguments[0].scrollIntoView(true);', elem).then(async () => { - await this.driver.sleep(150); - }); - }); - } - - async writeBase64ToPNG(filePath, base64String){ - let base64Data = base64String.replace(/^data:image\/png;base64,/,''); - fs.writeFile(filePath, - base64Data, - 'base64', - async err => { - if(err) { - console.log(err); - } - }); - } - - async writeMessageToConsoleLog(msg){ - await this.driver.executeScript('console.info(\'TO WHOM IT MAY CONCERN\')'); - await this.driver.executeScript('console.log(\'HELLO\')'); - await this.driver.executeScript('console.warn(\'BOO BOO BOO!\')'); - await this.driver.executeScript('console.error(\'AIEYAIYAI!\')'); - //try { - await this.driver.executeScript('throw new Error(\'WHADDAP?\')'); - //}catch(e){ - //ignore - //} - } - - async getConsoleLog(){ - console.log("DEBUG logging.Type.BROWSER " + logging.Type.BROWSER); - await this.driver.manage().logs().get(logging.Type.BROWSER).then(async logs => { - await console.log("DEBUG typeof(logs) " + JSON.stringify(logs)); - for(let log in logs){ - await console.log("DEBUG logs[log] #" + logs[log].message + "#"); - } - }) - } - - async sendKeysToCurrent(keys){ - let current = await this.driver.switchTo().activeElement(); - let actionList = keys.split(','); - for(let i = 0; i < actionList.length; i++){ - if(actionList[i].includes('+')){ //is chord - let chord = actionList[i].split('+'); - if(chord.length === 2){ - await current.sendKeys(Key.chord(keyMap[chord[0].toLowerCase()], - keyMap[chord[1].toLowerCase()])); - }else if(chord.length === 3){ - await current.sendKeys(Key.chord(keyMap[chord[0].toLowerCase()], - keyMap[chord[1].toLowerCase()], - keyMap[chord[2].toLowerCase()])); - - }else{ - throw `unsupported chord count ${actionList[i]}`; - } - - }else{ - await current.sendKeys(keyMap[actionList[i].toLowerCase()]); - } - } - } - - async startLiveDataGenerator(def){ - await influxUtils.startLiveDataGen(def); - } - - async stopLiveDataGenerator() { - await influxUtils.stopLiveDataGen(); - } - - async clickSortTypeDropdown(){ - await this.clickAndWait(await this.basePage.getSortTypeButton()); - } - - async clickSortByListItem(item){ - //Check for special items - if(item.startsWith('retentionRules[0]')){ - //don't normalize the string - await this.clickAndWait(await this.basePage.getSortTypeListItem(item, false)); - }else{ - await this.clickAndWait(await this.basePage.getSortTypeListItem(item)); - } - } - - async verifyAddLabelPopoverVisible(){ - await this.assertVisible(await this.basePage.getLabelPopover()); - } - - async verifyAddLabelsPopopverNotPresent(){ - await this.assertNotPresent(await basePage.getLabelPopoverSelector()); - } - - async verifyLabelPopoverContainsLabels(labels){ - let labelsList = labels.split(','); - for(const label of labelsList){ - let elem = await this.basePage.getLabelListItem(label.trim()) - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async verifyLabelPopoverDoesNotContainLabels(labels){ - let labelsList = labels.split(','); - for(const label of labelsList){ - await this.assertNotPresent(await basePage.getLabelListItemSelector(label.trim())); - } - - } - - async clickLabelPopoverItem(item){ - await this.clickAndWait(await this.basePage.getLabelListItem(item.trim())); - } - - async setLabelPopoverFilter(val){ - await this.clearInputText(await this.basePage.getLabelPopoverFilterField()); - await this.typeTextAndWait(await this.basePage.getLabelPopoverFilterField(), val); - } - - async verifyLabelPopoverCreateNew(name){ - await this.verifyElementContainsText(await this.basePage.getLabelPopoverCreateNewButton(), name); - } - - async verifyLabelPopupNoCreateNew(){ - await this.assertNotPresent(await basePage.getLabelPopoverCreateNewButtonSelector()); - } - - - async clearDashboardLabelsFilter(){ - await this.clearInputText(await this.basePage.getLabelPopoverFilterField()); - } - - - -} - -module.exports = baseSteps; diff --git a/e2e/src/steps/cloudSteps.js b/e2e/src/steps/cloudSteps.js deleted file mode 100644 index 0ec60934fa..0000000000 --- a/e2e/src/steps/cloudSteps.js +++ /dev/null @@ -1,106 +0,0 @@ -const { until } = require('selenium-webdriver') - -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -//const createOrgPage = require(__srcdir + '/pages/createOrgPage.js'); -const cloudLoginPage = require(__srcdir + '/pages/cloud/cloudLoginPage.js'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); -const perfUtils = require(__srcdir + '/utils/performanceUtils.js'); -const homePage = require(__srcdir + '/pages/home/homePage.js'); - -class cloudSteps extends baseSteps { - - constructor(driver){ - super(driver); - //this.createOrgPage = new createOrgPage(driver); - this.loginPage = new cloudLoginPage(driver); - this.homePage = new homePage(driver); - } - - //for driver sync - async isLoaded(){ - //await this.createOrgPage.isLoaded(); - } - - //for assrtions - async verifyIsLoaded(){ - //this.assertVisible(await this.createOrgPage.getInputOrgName()); - //this.assertVisible(await this.createOrgPage.getInputBucketName()); - //this.assertVisible(await this.createOrgPage.getbuttonCancel()); - //this.assertVisible(await this.createOrgPage.getbuttonCreate()); - } - - async openCloudPage(maxDelay){ - await perfUtils.execTimed(async () => { - await this.driver.get(__config.influx_url); - await this.loginPage.waitToLoad(10000); - }, - maxDelay, 'timely redirect failed'); - } - - async performanceBogusTest(sleep, delay){ - await perfUtils.execTimed( async() => { - await this.driver.sleep(sleep); - }, delay, "bogus test failed", 'bogus test succeeded'); - } - - async setupDefaultCloudUser(){ - await influxUtils.setupCloudUser('DEFAULT'); - } - - async openCloudLogin(){ - await this.openBase(); - //wait for login form to load - await this.loginPage.waitToLoad(10000); - - } - - async logInToCloud(){ - await this.typeTextAndWait(await this.loginPage.getEmailInput(), __defaultUser.username); - await this.typeTextAndWait(await this.loginPage.getPasswordInput(), __defaultUser.password); - await this.clickAndWait(await this.loginPage.getLogInButton()); - } - - async logInToCloudTimed(maxDelay){ - await this.typeTextAndWait(await this.loginPage.getEmailInput(), __defaultUser.username); - await this.typeTextAndWait(await this.loginPage.getPasswordInput(), __defaultUser.password); - await perfUtils.execTimed(async () => { - await this.clickAndWait(await this.loginPage.getLogInButton()); - try { - await this.driver.wait(until.elementIsVisible(await this.homePage.getNavMenu()), maxDelay * 3); - await this.driver.wait(until.elementIsVisible(await this.homePage.getPageHeader()), maxDelay * 3); - }catch(err){ - console.warn(JSON.stringify(err)); - //try again - await this.driver.wait(until.elementIsVisible(await this.homePage.getNavMenu()), maxDelay * 3); - await this.driver.wait(until.elementIsVisible(await this.homePage.getPageHeader()), maxDelay * 3); - } - },maxDelay, 'failed to timely open cloud '); - } - - //TODO - this is not checking correct page - see issue #19057 - //because currently not loading account info on logout like before - //not sure why... once logout to correct page is fixed update this method - //this is a holder so that other tests can be written - async logoutToAccountInfoTimed(maxDelay){ - await perfUtils.execTimed(async () => { - await this.clickAndWait(await this.homePage.getLogoutButton()); - await this.driver.wait(this.homePage.isLoaded(), maxDelay * 3); - }, maxDelay, 'failed to timely open info'); - } - - async logoutToLoginTimed(maxDelay){ - await perfUtils.execTimed(async () => { - await this.clickAndWait(await this.homePage.getLogoutButton()); - await this.loginPage.waitToLoad(10000); - }, maxDelay, 'login slow to reload'); - } - - async verifyCloudLoginPageLoaded(){ - await this.loginPage.isLoaded(); - } - - - -} - -module.exports = cloudSteps; diff --git a/e2e/src/steps/createOrgSteps.js b/e2e/src/steps/createOrgSteps.js deleted file mode 100644 index 2df3a03a63..0000000000 --- a/e2e/src/steps/createOrgSteps.js +++ /dev/null @@ -1,25 +0,0 @@ -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const createOrgPage = require(__srcdir + '/pages/createOrgPage.js'); - -class createOrgSteps extends baseSteps { - - constructor(driver){ - super(driver); - this.createOrgPage = new createOrgPage(driver); - } - - //for driver sync - async isLoaded(){ - await this.createOrgPage.isLoaded(); - } - - //for assertions - async verifyIsLoaded(){ - this.assertVisible(await this.createOrgPage.getInputOrgName()); - this.assertVisible(await this.createOrgPage.getInputBucketName()); - this.assertVisible(await this.createOrgPage.getbuttonCancel()); - this.assertVisible(await this.createOrgPage.getbuttonCreate()); - } -} - -module.exports = createOrgSteps; diff --git a/e2e/src/steps/dashboards/cellOverlaySteps.js b/e2e/src/steps/dashboards/cellOverlaySteps.js deleted file mode 100644 index 3ac50a579e..0000000000 --- a/e2e/src/steps/dashboards/cellOverlaySteps.js +++ /dev/null @@ -1,1098 +0,0 @@ -const fs = require('fs'); -const expect = require('chai').expect; -const Key = require('selenium-webdriver').Key; -const { By, Origin } = require('selenium-webdriver'); - -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const cellEditOverlay = require(__srcdir + '/pages/dashboards/cellEditOverlay.js'); - -class cellOverlaySteps extends influxSteps { - - constructor(driver) { - super(driver); - this.cellOverlay = new cellEditOverlay(driver); - } - - async verifyCellOverlayIsLoaded(title){ - await this.cellOverlay.isLoaded(); - await this.verifyElementContainsText(await this.cellOverlay.getCellTitle(), title); - } - - async nameDashboardCell(name){ - await this.cellOverlay.getCellTitle().then(async elem => { - await elem.click().then(async () => { - await this.cellOverlay.getCellNameInput().then(async input =>{ - await this.clearInputText(input).then(async () => { - await this.typeTextAndWait(input, name + Key.ENTER); - }); - }); - }); - }); - } - - async clickDashboardCellEditCancel(){ - await this.clickAndWait(await this.cellOverlay.getEditCancel()); - } - - async clickDashboardCellSave(){ - await this.clickAndWait(await this.cellOverlay.getSaveCell()); - } - - async clickCellEditTimeRangeDropdown(){ - await this.clickAndWait(await this.cellOverlay.getTMTimeRangeDropdown()); - } - - async selectCellEditTimeRangeItem(item){ - let itemToken = await item.replace(/\s/g,'').toLowerCase(); - await this.cellOverlay.getTMTimeRangeDropdownItem(itemToken).then(async elem => { - await this.scrollElementIntoView(elem).then(async () => { - await this.clickAndWait(await this.cellOverlay - .getTMTimeRangeDropdownItem(itemToken)); - }); - }); - } - - async clickCellEditScriptEditorButton(){ - await this.clickAndWait(await this.cellOverlay.getSwitchToScriptEditor()); - } - - async pasteIntoCellEditScriptEditor(text){ - //await this.setCodeMirrorText(await this.cellOverlay.getScriptEditorCodeMirror(), escapedTxt); - //await this.setMonacoEditorText(await this.cellOverlay.getScriptMonacoEditor(), escapedTxt); - await this.setMonacoEditorText(await this.cellOverlay.getScriptMonacoEditor(), text); - } - - async clearCellEditScriptEditor(){ - // await this.setCodeMirrorText(await this.cellOverlay.getScriptEditorCodeMirror(), ""); - await this.driver.sleep(1000); - //await this.setMonacoEditorText(await this.cellOverlay.getScriptMonacoEditor(), ""); - await this.clearMonacoEditorText(await this.cellOverlay.getScriptMonacoEditor()); - } - - async clickCellEditSubmitButton(){ - await this.clickAndWait(await this.cellOverlay.getTimemachineSubmit(), async () => { - await this.driver.sleep(1500); //todo better wait - sec and half to load for now - }); - } - - async verifyCellEditSubmitDisabled(){ - await this.verifyElementDisabled(await this.cellOverlay.getTimemachineSubmit()); - } - - async verifyCellEditSubmitEnabled(){ - await this.verifyElementEnabled(await this.cellOverlay.getTimemachineSubmit()); - } - - async getCurrentCellEditPreviewGraph(){ - - if(await this.isPresent(cellEditOverlay.getGraphCanvasSelector())) { - await this.cellOverlay.getGraphCanvas().then(async canvas => { - /* eslint-disable no-undef */ - __dataBuffer.graphEditCanvas = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvas); - console.log('DEBUG __dataBuffer.graphEditCanvas ' + __dataBuffer.graphEditCanvas); - await this.cellOverlay.getGraphCanvasAxes().then(async axes => { - __dataBuffer.graphEditCanvasAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', axes); - }); - }); - }else{ - __dataBuffer.graphEditCanvas = ''; - } - } - - async verifyCellEditPreviewGraphVisible(){ - await this.assertVisible(await this.cellOverlay.getGraphCanvas()); - } - - async verifyCellEditPreviewAxesVisible(){ - await this.assertVisible(await this.cellOverlay.getGraphCanvasAxes()); - } - - async verifyCellEditPreviewGraphChanged(){ - if(await this.isPresent(cellEditOverlay.getGraphCanvasSelector())) { - await this.cellOverlay.getGraphCanvas().then(async canvas => { - let currentCanvas = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', - canvas); - //visual DEBUG Below - //await this.writeBase64ToPNG('debug.png', currentCanvas); - //this.writeBase64ToPNG('canvas.png', __dataBuffer.graphEditCanvas); - expect(currentCanvas).to.not.equal(__dataBuffer.graphEditCanvas); - //Axes may or maynot change TODO look at axes comparison - /*await this.cellOverlay.getGraphCanvasAxes().then(async axes => { - let currentAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\').substring(21);', axes); - //visual DEBUG below - await this.writeBase64ToPNG('axes.png', currentAxes); - })*/ - }); - }else{ - throw new Error('Cell Edit Preview Graph Not Found'); - } - } - - async clickCellEditSaveButton(){ - await this.clickAndWait(await this.cellOverlay.getSaveCell()); - } - - async clickCellEditName(){ - await this.clickAndWait(await this.cellOverlay.getCellTitle()); - } - - async updateCellName(name){ - await this.clearInputText(await this.cellOverlay.getCellNameInput()); - await this.typeTextAndWait(await this.cellOverlay.getCellNameInput(), name); - } - - async clickViewTypeDropdown(){ - await this.clickAndWait(await this.cellOverlay.getViewTypeDropdown()); - } - - async verifyViewTypeListContents(itemList){ - let list = itemList.split(','); - for(let i = 0; i < list.length; i++){ - let elem = await this.cellOverlay.getViewTypeItem(list[i]); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async verifyViewTypeListNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getViewTypeListContentsSelector()); - } - - async clickCellViewCustomize(){ - await this.clickAndWait(await this.cellOverlay.getCustomizeButton()); - } - - async verifyViewOptionsContainerVisible(){ - await this.assertVisible(await this.cellOverlay.getViewOptionsContainer()); - } - - async verifyCellCustomizeButtonHighlight(){ - await this.verifyElementContainsClass(await this.cellOverlay.getCustomizeButton() - , 'button-primary'); - } - - async verifyViewOptionsContainerNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getViewOptionsContainerSelector()); - } - - async verifyCustomizeButtonNoHighlightd(){ - await this.verifyElementDoesNotContainClass(await this.cellOverlay.getCustomizeButton() - , 'button-primary'); - } - - async verifyTMViewEmptyQueriesGraphVisible(){ - await this.assertVisible(await this.cellOverlay.getTMViewEmptyGraphQueries()); - } - - async verifyTMViewNoResultsVisible(){ - await this.assertVisible(await this.cellOverlay.getTMViewNoResults()); - } - - async clickTMAutorefreshDropdown(){ - await this.clickAndWait(await this.cellOverlay.getTMAutorefreshDropdown()); - } - - async verifyAutorefreshListContents(itemList){ - let list = itemList.split(','); - for(let i = 0; i < list.length; i++){ - await this.assertVisible(await this.cellOverlay.getTMAutorefreshItem(list[i])); - } - } - - async clickTMAutorefreshItem(item){ - await this.clickAndWait(await this.cellOverlay.getTMAutorefreshItem(item)); - } - - async verifyTMAutorefreshForceButtonNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getTMAutorefreshForceButtonSelector()); - } - - async verifyTMAutorefreshForceButtonVisible(){ - await this.assertVisible(await this.cellOverlay.getTMAutorefreshForceButton()); - } - - async verifyTMAutorefreshDropdownSelected(selected){ - - if(selected.toLowerCase() === 'paused'){ - await this.assertVisible(await this.cellOverlay.getTMAutorefreshDropdownPaused()); - }else { - - await this.cellOverlay.getTMAutorefreshDropdownSelected().then(async elem => { -// console.log("DEBUG selected #" + await elem.getText() + "#"); - await this.driver.executeScript('arguments[0].style.border=\'3px solid red\'', elem); - console.log("DEBUG selected #" + JSON.stringify(elem) + "#"); - }); - await this.verifyElementText(await this.cellOverlay.getTMAutorefreshDropdownSelected(), selected) - } - } - - async clickTMForceRefresh(){ - await this.clickAndWait(await this.cellOverlay.getTMAutorefreshForceButton()); - } - - async verifyTMTimeRangeDropdownList(itemList){ - let list = itemList.split(','); - for(let i = 0; i < list.length; i++){ - let elem = await this.cellOverlay - .getTMTimeRangeDropdownItem(list[i] - .replace(/\s/g,'') - .toLowerCase()); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async verifyTMTimeRangeDropdownListNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getTMTimeRangeDropdownContentsSelector()); - } - - async verifyTMQueryBuilderVisible(){ - await this.assertVisible(await this.cellOverlay.getTMQueryBuilder()); - } - - async verifyTMQueryBuilderSwitchWarnNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getTMSwitchToQBuilderWarnSelector()); - } - - async verifyTMQueryBuilderSwitchWarnVisible(){ - await this.assertVisible(await this.cellOverlay.getTMSwitchToQBuilderWarn()); - } - - async verifyTMFluxEditorVisible(){ - await this.assertVisible(await this.cellOverlay.getTMFluxEditor()); - } - - async clickTMSwitch2QBuilder(){ - await this.clickAndWait(await this.cellOverlay.getTMSwitchToQueryBuilder()); - } - - async clickTMSwitch2QBuilderConfirm(){ - await this.clickAndWait(await this.cellOverlay.getTMSwitchToQBuilderConfirm()); - } - - async clickTMFluxEditor(){ - await this.clickAndWait(await this.cellOverlay.getTMFluxEditor()); - } - - async clickTMFilterFunctionsInput(){ - await this.clickAndWait(await this.cellOverlay.getTMQEFunctionFilter()); - } - - async verifyTMFluxEditorNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getTMFluxEditorSelector()); - } - - async verifyTMBucketListContents(bucketList){ - let list = bucketList.split(','); - for(let i = 0; i < list.length; i++){ - await this.assertVisible(await this.cellOverlay.getTMBucketSelectorBucket(list[i].trim())); - } - } - - async clickTMBucketSelectorItem(item){ - await this.clickAndWait(await this.cellOverlay.getTMBucketSelectorBucket(item.trim()), - async () => { await this.driver.sleep(1000); }); //slow to load sometimes? - } - - async verifyBucketNotInTMBucketList(bucket){ - await this.assertNotPresent(cellEditOverlay.getTMBucketSelectorBucketSelector(bucket)); - } - - async filterBucketListContents(value){ - await this.clearInputText(await this.cellOverlay.getTMBucketSelectorFilter()); - await this.typeTextAndWait(await this.cellOverlay.getTMBucketSelectorFilter(), value); - } - - async clearBucketSelectorFilter(){ - await this.clearInputText(await this.cellOverlay.getTMBucketSelectorFilter()); - } - - async verifyTMBuilderCardsSize(count){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await expect(cards.length).to.equal(parseInt(count)); - } - - async verifyItemsInBuilderCard(index,items){ - let cards = await this.cellOverlay.getTMBuilderCards(); - let list = items.split(','); - for(let i = 0; i < list.length; i++){ - await this.assertVisible(await cards[parseInt(index) - 1] - .findElement(By.css(`[data-testid='selector-list ${list[i].trim()}']`))); - } - } - - async verifyItemSelectedInBuilderCard(index, item){ - let card = await this.cellOverlay.getTMBuilderCardByIndex(parseInt(index)); - await this.verifyElementContainsClass(await card.findElement(By.css(`[data-testid='selector-list ${item.trim()}']`)), - 'selected'); - - } - - async verifyEmptyTagsInBuilderCard(index){ - await this.cellOverlay.getTMBuilderCardByIndex(index).then(async elem => { - await this.assertVisible(await elem.findElement(By.css('[data-testid=\'empty-tag-keys\']'))); - }); - } - - async verifyNoSelectedTagsInBuilderCard(index){ - await this.cellOverlay.getTMBuilderCardByIndex(index).then(async elem => { - await elem.findElements(By.css('[data-testid^=selector-list][class*=selected]')) - .then(async items => { - await expect(await items.length).to.equal(0); - }); - }); - } - - async verifySelectorCountInBuilderCard(index,value){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await cards[parseInt(index) - 1] - .findElement(By.css('.tag-selector--count')) - .then(async elem => { - await this.verifyElementContainsText(elem, value); - }); - } - - async verifyItemNotInBuilderCard(index,item){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await cards[parseInt(index) - 1] - .findElements(By.css(`[data-testid='selector-list ${item.trim()}']`)) - .then(async elems => { - expect(await elems.length).to.equal(0); - }); - } - - async clickTagSelectorOfBuilderCard(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await this.clickAndWait(await cards[parseInt(index) - 1] - .findElement(By.css('[data-testid=tag-selector--dropdown-button]'))); - } - - async verifyItemsInBuilderCardTagSelector(index,items){ - let cards = await this.cellOverlay.getTMBuilderCards(); - let list = items.split(','); - for(let i = 0; i < list.length; i++){ - await this.assertVisible(await cards[parseInt(index) - 1] - .findElement(By.css(`[data-testid='searchable-dropdown--item ${list[i].trim()}']`))); - } - } - - async clickTagSelectorDropdownItemInBuilderCard(item,index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await this.clickAndWait(await cards[parseInt(index) - 1] - .findElement(By.css(`[data-testid='searchable-dropdown--item ${item.trim()}']`))); - } - - async clickTagInBuilderCard(tag, cardIndex){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await this.clickAndWait(await cards[parseInt(cardIndex) - 1] - .findElement(By.css(`[data-testid='selector-list ${tag}']`))); - } - - async clickBuilderCardDelete(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await this.clickAndWait(await cards[parseInt(index) - 1] - .findElement(By.css('.builder-card--delete'))); - } - - async filterBuilderCardListContents(index,term){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await this.typeTextAndWait(await cards[parseInt(index) - 1] - .findElement(By.css('[data-testid=\'input-field\']')), term, - async () => { await this.driver.sleep(2000); }); //can be slow to update - //this.driver.sleep(2000); //DEBUG - } - - async clearTagsFilterInBuilderCard(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await this.clearInputText(await cards[parseInt(index) - 1] - .findElement(By.css('[data-testid=\'input-field\']'))); - } - - async verifyBuilderCardEmpty(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await this.assertVisible(await cards[parseInt(index) - 1] - .findElement(By.css('[data-testid=\'builder-card--empty\']'))); - } - - async verifyBuilderCardTagSelectNotPresent(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await cards[parseInt(index) - 1] - .findElements(By.css('[data-testid=tag-selector--dropdown-menu--contents]')) - .then(async elems => { - expect(await elems.length).to.equal(0); - }); - } - - async verifyBuilderCardSelectCountNotPresent(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await cards[parseInt(index) - 1] - .findElements(By.css('.tag-selector--count')) - .then(async elems => { - expect(await elems.length).to.equal(0); - }); - } - - async verifyBuilderCardDeleteNotPresent(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - await cards[parseInt(index) - 1] - .findElements(By.css('.builder-card--delete')) - .then(async elems => { - expect(await elems.length).to.equal(0); - }); - } - - async closeAllTMQBCards(){ - let cards = await this.cellOverlay.getTMBuilderCards(); - for(let i = cards.length - 1; i > 0; i--){ //close all but last card - await this.clickAndWait(await cards[i].findElement(By.css('.builder-card--delete'))); - } - } - - async deselectAllActiveTagsInTMQBCard(index){ - let cards = await this.cellOverlay.getTMBuilderCards(); - let selecteds = await cards[parseInt(index)-1].findElements(By.css('.selector-list--checkbox.selected')); - for(let i = 0; i < selecteds.length; i++){ - await this.clickAndWait(selecteds[i]); - } - } - - async verifyTMQueryBuilderFunctionDuration(duration){ - await this.verifyInputEqualsValue(await this.cellOverlay.getTMBuilderCardMenuDurationInput(), duration); - } - - async clickCustomFunctionGroup(){ - await this.clickAndWait(await this.cellOverlay.getTMQBCustomFunctionGroup()); - } - - async clickTMQueryBuilderFunctionDuration(){ - await this.clickAndWait(await this.cellOverlay.getTMBuilderCardMenuDurationInput()); - } - - async clickTMQueryBuilderCustomDuration(){ - await this.clickAndWait(await this.cellOverlay.getTMQBCustomWindowPeriod()); - } - - async clickTMQueryBuilderAutoDuration(){ - await this.clickAndWait(await this.cellOverlay.getTMQBAutoWindowPeriod()); - } - - async verifyTMQBFunctionDurationSuggestionCount(count){ - await this.cellOverlay.getTMQBDurationSuggestions().then(async elems => { - expect(await elems.length).to.equal(parseInt(count)); - }); - } - - async verifyTMQBFunctionDurationSuggestionItems(items){ - let list = items.split(','); - for (let i = 0; i < list.length; i++){ - let elem = await this.cellOverlay.getTMQBDurationSuggestionByName(list[i].trim()); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async clickTMQBFunctionDurationSuggestionItem(item){ - let elem = await this.cellOverlay.getTMQBDurationSuggestionByName(item.trim()); - await this.scrollElementIntoView(elem); - await this.clickAndWait(elem); - } - - async verifyTMQueryBuilderFunctionListItems(items){ - let list = items.split(','); - for(let i = 0; i < list.length; i++){ - let elem = await this.cellOverlay.getTMBuilderCardMenuFunctionListItem(list[i].trim()); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - - } - - async filterQueryBuilderFunctionList(term){ - await this.typeTextAndWait(await this.cellOverlay.getTMBuilderCardMenuFunctionFilter(), term); - } - - async clearQueryBuilderFunctionListFilter(){ - await this.clearInputText(await this.cellOverlay.getTMBuilderCardMenuFunctionFilter()); - } - - async verifyQuerBuilderFunctionListItemCount(count){ - await this.cellOverlay.getTMBuilderCardMenuFunctionListItems().then(async elems => { - await expect(await elems.length).to.equal(parseInt(count)); - }); - } - - async getTMPreviewMetrics(){ - /*await this.dbdPage.getCellByName(name).then(async cell => { - await cell.getRect().then(async rect => { - // console.log("DEBUG rect for " + name + " " + JSON.stringify(rect)) - if(typeof __dataBuffer.rect === 'undefined'){ - __dataBuffer.rect = []; - } - __dataBuffer.rect[name] = rect; - //debug why resize not saved - //await influxUtils.signInAxios('admin'); - //let dashboards = await influxUtils.getDashboards(); - //console.log("DEBUG dashboards " + JSON.stringify(dashboards)); - - }) - })*/ - - await this.cellOverlay.getTMTop().then(async cell => { - // TODO generalize the following into system wide method - await cell.getRect().then(async rect => { - if(typeof __dataBuffer.rect === 'undefined'){ - __dataBuffer.rect = []; - } - __dataBuffer.rect['TMTop'] = rect; - - }); - }); - } - - async getTMPQueryAreaMetrics(){ - await this.cellOverlay.getTMBottom().then(async cell => { - await cell.getRect().then(async rect => { - if(typeof __dataBuffer.rect === 'undefined'){ - __dataBuffer.rect = []; - } - __dataBuffer.rect['TMBottom'] = rect; - - }); - }); - } - - async getTMPreviewCanvas(){ - await this.cellOverlay.getGraphCanvas().then(async canvas => { - if(typeof __dataBuffer.graphCellLine === 'undefined') { - __dataBuffer.graphCellLine = []; - } - /* eslint-disable require-atomic-updates */ - __dataBuffer.graphCellLine['TMPreview'] = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvas); - }); - } - - async getTMPreviewCanvasAxes(){ - await this.cellOverlay.getGraphCanvasAxes().then(async axes => { - if(typeof __dataBuffer.graphCellAxes === 'undefined') { - __dataBuffer.graphCellAxes = []; - } - __dataBuffer.graphCellAxes['TMPreviewAxes'] = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', axes); - }); - } - - async resizeTMPreviewBy(deltaSize){ - - await this.cellOverlay.getTMResizerHandle().then(async resizer => { - - - - let action = await this.driver.actions(); - let action2 = await this.driver.actions(); - await action //troubleshoot why action occasionally fails - .move({x:0, y: 0, origin: resizer, duration: 500}) - .press().perform(); - await this.driver.sleep(1000); //wait for animation - await action2.move({x: 0, y: parseInt(deltaSize.dh), origin: resizer, duration: 500}) - .release() - .perform(); - await this.driver.sleep(1000); //slight wait for animation - - }); - } - - //todo - generalize this for different elements - async verifyTMPreviewAreaSizeChange(deltaSize){ - - let tolerance = 10; - await this.cellOverlay.getTMTop().then(async preview => { - let rect = await preview.getRect(); - //console.log("DEBUG rect " + JSON.stringify(rect)) - let width = parseInt(rect.width); - let height = parseInt(rect.height); - let dw = parseInt(deltaSize.dw); - let dh = parseInt(deltaSize.dh); - let exph = parseInt(__dataBuffer.rect['TMTop'].height) + dh; - let expw = parseInt(__dataBuffer.rect['TMTop'].width) + dw; - expect(Math.abs(exph - height )).to.be.below(tolerance); - expect(Math.abs(expw - width )).to.be.below(tolerance); - - }); - - } - - //todo - generalize this for different elements - async verifyTMQBAreaSizeChange(deltaSize){ - let tolerance = 10; - await this.cellOverlay.getTMBottom().then(async preview => { - let rect = await preview.getRect(); - //console.log("DEBUG rect " + JSON.stringify(rect)) - let width = parseInt(rect.width); - let height = parseInt(rect.height); - let dw = parseInt(deltaSize.dw); - let dh = parseInt(deltaSize.dh); - let exph = parseInt(__dataBuffer.rect['TMBottom'].height) + dh; - let expw = parseInt(__dataBuffer.rect['TMBottom'].width) + dw; - expect(Math.abs(exph - height )).to.be.below(tolerance); - expect(Math.abs(expw - width )).to.be.below(tolerance); - - }); - - } - - async verifyTMPreviewCanvasChange(){ - await this.driver.sleep(3000); //troubleshoot why no change - await this.cellOverlay.getGraphCanvas().then(async canvasLine => { - let currentLine = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); -/* - await fs.writeFile('before.png', __dataBuffer.graphCellLine['TMPreview'].split(',')[1], 'base64', (err) => { - if (err) { - console.log(err); - } - }); - - - await fs.writeFile('after.png', currentLine.split(',')[1], 'base64', (err) => { - if (err) { - console.log(err); - } - }); -*/ - await expect(currentLine).to.not.equal(__dataBuffer.graphCellLine['TMPreview']); - }); - } - - async verifyTMPreviewCanvasNoChange(){ - await this.cellOverlay.getGraphCanvas().then(async canvasLine => { - let currentLine = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - - await expect(currentLine).to.equal(__dataBuffer.graphCellLine['TMPreview']); - }); - - } - - async verifyTMPreviewAxesChange(){ - await this.cellOverlay.getGraphCanvasAxes().then(async canvasAxes => { - let currentAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - await expect(currentAxes).to.not.equal(__dataBuffer.graphCellAxes['TMPreviewAxes']); - }); - } - - async verifyTMPreviewCanvasNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getGraphCanvasSelector()); - } - - async verifyTMPreviewCanvasAxesNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getGraphCanvasAxesSelector()); - } - - async clickTMAddQuery(){ - await this.clickAndWait(await this.cellOverlay.getTMBuilderTabsAddQuery()); - } - - async verifyTMQueryBucketSelected(bucket){ - await this.verifyElementContainsText(await this.cellOverlay.getTMQBSelectedBucket(), bucket); - - } - - async verifyTMQueryCardSelected(index,tag){ - await this.verifyElementContainsText(await this.cellOverlay - .getTMQBSelectedTagOfCard(parseInt(index) - 1), tag); - } - - async verifyTMQueryFunctionsSelected(funcs){ - let list = funcs.split(','); - for(let i = 0; i < list.length; i++){ - await this.cellOverlay.getTMQBSelectedFunctionByName(list[i].trim()).then(async elems => { - expect(elems.length).to.equal(1, ` selected function ${list[i]} should occur once` ); - }); - } - - } - - async clickTMQBFunction(func){ - await this.clickAndWait(await this.cellOverlay.getTMBuilderCardMenuFunctionListItem(func)); - } - - async verifyTMQBActiveQuery(name){ - await this.cellOverlay.getTMQBActiveQueryTab().then(async tab => { - await tab.findElement(By.css('.query-tab--name')).then(async elem => { - this.verifyElementContainsText(elem, name); - }); - }); - } - - async clickOnTMQBQueryTab(title){ - await this.clickAndWait(await this.cellOverlay.getTMQBQueryTabByName(title)); - } - - async rightClickTMQBQueryTabTitle(title){ - await this.cellOverlay.getTMQBQueryTabByName(title).then(async elem => { - let action = this.driver.actions(); - - await action.contextClick(elem).perform(); - }); - } - - async clickTMQBQueryTabRightClickMenuItem(item){ - await this.clickAndWait(await this.cellOverlay.getTMQBRightClickItem(item)); - } - - async enterNewTMQBQueryTabName(name){ - await this.typeTextAndWait(await this.cellOverlay.getTMQBQueryTabNameInput(), - name + Key.ENTER); - } - - async verifyNoTMQBQueryTabNamed(name){ - await this.assertNotPresent(cellEditOverlay.getTMQBQueryTabSelectorByName(name)); - } - - async clickRightTMQBQuery(name){ - - await this.clickRAndWait(await this.cellOverlay.getTMQBQueryTabByName(name)); - - /* - await this.cellOverlay.getTMQBQueryTabByName(name).then(async tab => { - await this.clickRAndWait(tab); - }); - */ - } - - async clickTMQBHideQuery(name){ - await this.cellOverlay.getTMQBQueryTabByName(name).then(async tab => { - await this.clickAndWait(await tab.findElement(By.css('.query-tab--hide'))); - }); - } - - async clickTMQBDeleteQuery(name){ - await this.cellOverlay.getTMQBQueryTabByName(name).then(async tab => { - await this.clickAndWait(await tab.findElement(By.css('.query-tab--close'))); - }); - } - - async verifyTMQBNumberOfQueryTabs(count){ - await this.cellOverlay.getTMQBQueryTabs().then(async elems => { - await expect(elems.length).to.equal(parseInt(count), - `Expected number of query tabs to equals ${count}`); - }); - } - - async verifyTMQBScriptEditorContents(script){ - let text = await this.getMonacoEditorText(); - await expect(text.trim()).to.equal(script.trim()); - } - - async updateTMQBScriptEditorContents(script){ - await this.clearMonacoEditorText(await this.cellOverlay.getScriptMonacoEditor()); - await this.setMonacoEditorText(await this.cellOverlay.getScriptMonacoEditor(), script); - } - - async verifyTMEmptyGraphErrorMessage(msg){ - await this.verifyElementContainsText(await this.cellOverlay.getTMEmptyGraphErrMessage(), msg); - } - - async verifyTMQEFunctionCategoriesDisplayed(cats){ - let catList = cats.split(','); - for(let i = 0; i < catList.length; i++){ - await this.scrollElementIntoView(await this.cellOverlay.getTMQEFunctionCategory(catList[i].trim())); - await this.assertVisible(await this.cellOverlay.getTMQEFunctionCategory(catList[i].trim())); - } - } - - async filterTMQEFunctionsList(term){ - await this.typeTextAndWait(await this.cellOverlay.getTMQEFunctionFilter(), term); - } - - async clearTMQEFunctionsListFilter(){ - await this.clearInputText(await this.cellOverlay.getTMQEFunctionFilter()); - } - - async verifyTMQEVisibleFunctions(funcs){ - let funcList = funcs.split(','); - for(let i = 0; i < funcList.length; i++){ - await this.scrollElementIntoView(await this.cellOverlay.getTMQEFunctionListItem(funcList[i].trim())); - await this.assertVisible(await this.cellOverlay.getTMQEFunctionListItem(funcList[i].trim())); - } - } - - async verifyTMQENotVisibleFunctions(funcs){ - let funcList = funcs.split(','); - for(let i = 0; i < funcList.length; i++) { - await this.assertNotPresent(cellEditOverlay.getTMQEFunctionListItemSelector(funcList[i].trim())); - } - } - - async clickTMQEFunction(func){ - await this.scrollElementIntoView(await this.cellOverlay.getTMQEFunctionListItem(func.trim())); - await this.clickAndWait(await this.cellOverlay.getTMQEFunctionListItem(func.trim())); - } - - async clickInjectTMQEFunction(func){ - await this.scrollElementIntoView(await this.cellOverlay.getTMQEFunctionListItem(func.trim())); - await this.hoverOver(await this.cellOverlay.getTMQEFunctionListItem(func.trim())) - await this.clickAndWait(await this.cellOverlay.getTMQEFunctionListItemInjector(func.trim())); - } - - async hoverOverTMQEFunction(func){ - await this.scrollElementIntoView(await this.cellOverlay.getTMQEFunctionListItem(func.trim())); - await this.hoverOver(await this.cellOverlay.getTMQEFunctionListItem(func.trim())); - } - - async verifyTMQEFunctionPopupDescription(text){ - await this.verifyElementText(await this.cellOverlay.getTMQEFunctionPopupDescription(), text); - } - - async verifyTMQEFunctionPopupSnippet(text){ - await this.verifyElementText(await this.cellOverlay.getTMQEFunctionPopupSnippet(), text); - } - - async verifyTMQEFunctionPopupNotVisible(){ - await this.assertNotPresent(cellEditOverlay.getTMQEFunctionPopupSelector()); - } - - async hoverOverTMQETimerangeDropdown(){ - await this.hoverOver(await this.cellOverlay.getTMTimeRangeDropdown()); - } - - async hoverOverTMCellEditSubmit(){ - await this.hoverOver(await this.cellOverlay.getTimemachineSubmit()); - } - - async sendKeysToTimeMachineFluxEditor(keys){ - await this.sendMonacoEditorKeys(await this.cellOverlay.getScriptMonacoEditor(), keys); - } - - async verifyTMRawDataTableNotPresent(){ - await this.assertNotPresent(cellEditOverlay.getTMRawDataTableSelector()); - } - - async verifyTMRawDataTablePresent(){ - await this.assertVisible(await this.cellOverlay.getTMRawDataTable()); - } - - async clickTMRawDataToggle(){ - await this.clickAndWait(await this.cellOverlay.getTMRawDataToggle()); - } - - async scrollTMRawDataTableHorizontally(dist){ - - await this.cellOverlay.getTMRawDataScrollHThumb().then(async scroller => { - - let action = await this.driver.actions(); - - await action.move({x: 0, y: 0, origin: scroller, duration: 500}) - .press() - .move({ x: dist, y: 0, origin: scroller, duration: 500 }) - .perform(); - }); - - } - - async scrollTMRawDataTableVertically(dist){ - - await this.cellOverlay.getTMRawDataScrollVThumb().then(async scroller => { - - let action = await this.driver.actions(); - - await action.move({x: 0, y: 0, origin: scroller, duration: 500}) - .press() - .move({ x: 0, y: dist, origin: scroller, duration: 500 }) - .perform(); - - }); - - } - - async calculateTMRawDataVisibleTableRow(){ - - let results = []; - - console.log("DEBUG calculateTMRawDataTableRow enter") - - let i = 0; - let lastLeft = -1; - let cell = await this.cellOverlay.getTMRawDataCellByIndex(i + 1); - let currLeft = parseInt(await cell.getCssValue('left')); - console.log("DEBUG currLeft " + currLeft + " lastLeft " + lastLeft); - while(currLeft > lastLeft){ - let rec = {}; - rec.width = parseInt(await cell.getCssValue('width')); - rec.val = await cell.getText(); - results[i] = rec; - //console.log(`DEBUG results[${i}] ${results[i].width} ${results[i].val}`); - lastLeft = parseInt(await cell.getCssValue('left')); - i++; - cell = await this.cellOverlay.getTMRawDataCellByIndex(i + 1); - currLeft = parseInt(await cell.getCssValue('left')); - //console.log("DEBUG currLeft " + currLeft + " lastLeft " + lastLeft); - } - - console.log("DEBUG calculateTMRawDataTableRow exit") - - return results; - - } - - async verifyTMRawDataCellContents(coords, value){ - let cells = await this.cellOverlay.getTMRawDataCells(); - /* let grid = await this.cellOverlay.getTMRawDataReactGrid(); - let trackH = await this.cellOverlay.getTMRawDataScrollTrackH(); - let trackHWidth = parseInt(await trackH.getCssValue('width')); - let trackV = await this.cellOverlay.getTMRawDataScrollTrackV(); - let strdH = parseInt(await cells[0].getCssValue('height')); - let typW = parseInt(await cells[0].getCssValue('width')); - console.log("DEBUG coords " + JSON.toString(coords)); - console.log("DEBUG value " + value); - console.log("DEBUG cells.length " + await cells.length); - console.log("DEBUG cells[0].top " + await cells[0].getCssValue('top')); - console.log("DEBUG cells[0].left " + await cells[0].getCssValue('left')); - console.log("DEBUG strdH " + strdH); - console.log("DEBUG typW " + typW); - console.log("DEBUG ReactGrid w: " + await grid.getCssValue('width') + - " h: " + await grid.getCssValue('height')); - console.log("DEBUG trackH.width " + await trackH.getCssValue('width')); - console.log("DEBUG trackV.height " + await trackV.getCssValue('height')); - - let rowWidths = await this.calculateTMRawDataVisibleTableRow(cells); - let rowWidth = 0; - for(let i = 0; i < rowWidths.length; i++){ - rowWidth += rowWidths[i].width; - } - - console.log("DEBUG rowWidths " + rowWidths); - console.log("DEBUG rowWidth " + rowWidth); - console.log("DEBUG type coords.x " + typeof(coords.x)); - if(coords.x > rowWidths.length){ - console.log("need to scroll horizontally rowWidth type " + typeof(rowWidth) + " trackHWidth type " + typeof(trackHWidth)) - await this.scrollTMRawDataTableHorizontally(rowWidth - trackHWidth); - } - - */ - - let rowWidths = await this.calculateTMRawDataVisibleTableRow(cells); - let cellIndex = 1 + coords.x + coords.y * (rowWidths.length); //N.B. nth-of starts with index of 1 - console.log("DEBUG cellIndex " + cellIndex); - let targetCell = await this.cellOverlay.getTMRawDataCellByIndex(cellIndex); - console.log("DEBUG cell text " + await targetCell.getText()); - await this.assertVisible(targetCell); //should not be visible after scroll - - //Find column location by left - //Find next row when left:0 or left:lower than previous cell - //move right or left using scroll below - use width of first cell as guied (2 * width) - // await this.scrollTMRawDataTableHorizontally(typW); - // await this.scrollTMRawDataTableVertically(strdH); - //scroll down based on height - which should be standard - //use top / height to determine row - } - - async scrollTMRawDataTable(coords){ - if(coords.x !== 0){ - await this.scrollTMRawDataTableHorizontally(coords.x); - } - - if(coords.y !== 0){ - await this.scrollTMRawDataTableVertically(coords.y); - } - } - - async clickTMDownloadCSV(){ - await this.clickAndWait(await this.cellOverlay.getTMDownloadCSV(), - async () => { await this.driver.sleep(2000) }); //todo better wait - 2 sec to download - await influxUtils.dumpDownloadDir(); - } - - async clickTMQEVariablesTab(){ - await this.clickAndWait(await this.cellOverlay.getTMQEVariablesTab()); - } - - async verifyTMQEVariablesList(varList){ - let list = varList.split(','); - for(let i = 0; i < list.length; i++){ - await this.assertVisible(await this.cellOverlay.getTMQEVariablesLabel(list[i].trim())); - } - } - - async verifyTMQWVarieblesListAbsent(varList){ - let list = varList.split(','); - for(let i = 0; i < list.length; i++){ - await this.assertNotPresent(await cellEditOverlay.getTMQEVariablesLabelSelector(list[i].trim())); - } - } - - async enterTMQEVariableFilterValue(value){ - await this.typeTextAndWait(await this.cellOverlay.getTMQEVariablesFilter(), value) - } - - async clearTMQEVariablesFilter(){ - await this.clearInputText(await this.cellOverlay.getTMQEVariablesFilter()); - } - - async hoverOverTMQEVariable(varname){ - await this.hoverOver(await this.cellOverlay.getTMQEVariablesLabel(varname.trim())); - } - - async clickTMQEVariable(varname){ - await this.clickAndWait(await this.cellOverlay.getTMQEVariablesLabel(varname.trim())); - } - - async clickInjectTMQEVariable(varname){ - await this.hoverOver(await this.cellOverlay.getTMQEVariablesLabel(varname.trim())); - await this.clickAndWait(await this.cellOverlay.getTMQEVariablesInject(varname.trim())); - } - - async verifyTMQEVariablePopoverNotVisible(){ - await this.assertNotPresent(await cellEditOverlay.getTMQEVariablesPopoverSelector()) - } - - async verifyTMQEVariablePopoverVisible(){ - await this.assertVisible(await this.cellOverlay.getTMQEVariablesPopover()); - } - - async clickTMQEVariablePopoverVarDropdown(){ - - await this.driver.executeScript('arguments[0].style.border=\'3px solid red\'', - await this.cellOverlay.getTMQEVariablesPopoverContents()); - - await this.hoverOver(await this.cellOverlay.getTMQEVariablesPopoverContents()); - - await this.driver.sleep(500); -/* - await this.driver.executeScript('arguments[0].style.border=\'3px solid red\'', - await this.cellOverlay.getTMQEVariablePopoverDropdown()); - - let elem = await this.cellOverlay.getTMQEVariablesLabel('KARTA'); - - let dd = await this.cellOverlay.getTMQEVariablePopoverDropdown(); - console.log("DEBUG dd " + JSON.stringify(await dd.getRect())); - console.log("DEBUG elem " + JSON.stringify(await elem.getRect())); - console.log("DEBUG win " + JSON.stringify(await this.driver.manage().window().getRect())); - //await this.driver.sleep(1); - //let action = await this.driver.actions(); - //await action.move({x: -100, y:5, origin: Origin.POINTER, duration: 500}) - // .perform(); - - //await dd.click(); - - //await this.driver.executeScript('arguments[0].click()', - // await this.cellOverlay.getTMQEVariablePopoverDropdown()); - - await this.driver.sleep(3000); */ - // for some reason standard methods cause popover to disappear - //await this.hoverOver(await this.cellOverlay.getTMQEVariablePopoverDropdown()); - //await this.clickAndWait(await this.cellOverlay.getTMQEVariablePopoverDropdown()); - } - -} - -module.exports = cellOverlaySteps; diff --git a/e2e/src/steps/dashboards/dashboardSteps.js b/e2e/src/steps/dashboards/dashboardSteps.js deleted file mode 100644 index e5755d1748..0000000000 --- a/e2e/src/steps/dashboards/dashboardSteps.js +++ /dev/null @@ -1,675 +0,0 @@ -const expect = require('chai').expect; -const assert = require('chai').assert; -const { Key, until, By } = require('selenium-webdriver'); - -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const dashboardPage = require(__srcdir + '/pages/dashboards/dashboardPage.js'); -//const basePage = require(__srcdir + '/pages/basePage.js'); -const cellEditOverlay = require(__srcdir + '/pages/dashboards/cellEditOverlay.js'); -//const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -class dashboardSteps extends influxSteps { - - constructor(driver) { - super(driver); - this.dbdPage = new dashboardPage(driver); - this.cedOverlay = new cellEditOverlay(driver); - } - - async nameDashboard(name){ - await this.dbdPage.getPageTitle().then(async elem => { - await elem.click().then( async () => { - await this.dbdPage.getNameInput().then(async input => { - await this.clearInputText(input); - //await input.clear().then(async () => { // input.clear not working consistently here - await input.sendKeys(name + Key.ENTER).then(async () => { - }); - //}); - }); - }); - }); - } - - async verifyDashboardLoaded(name){ - await this.dbdPage.isLoaded(); - await this.dbdPage.getPageTitle().then(async title => { - await title.getText().then(async text => { - await expect(text).to.equal(name); - }); - }); - - } - - async verifyDashboardCellVisible(name){ - await this.assertVisible(await this.dbdPage.getCellByName(name)); - } - - async verifyDashboardEmptyDocLinkVisible(){ - await this.assertVisible(await this.dbdPage.getEmptyStateTextLink()); - } - - async verifyDashboardEmptyDocLink(link){ - await this.verifyElementAttributeContainsText(await this.dbdPage.getEmptyStateTextLink(), - 'href', link); - } - - async verifyDashboardEmptyAddCell(){ - await this.assertVisible(await this.dbdPage.getEmptyStateAddCellButton()); - } - - async clickDashboardTimeLocaleDropdown(){ - await this.clickAndWait(await this.dbdPage.getTimeLocaleDropdown()); - } - - async verifyDashboardDropdownContains(items){ - let itemArr = items.split(','); - for(let i = 0; i < itemArr.length; i++){ - await this.dbdPage.getDropdownMenuItem(itemArr[i].trim()).then(async elem => { - assert(true, `${await elem.getText()} is in list`); - }).catch(() => { - assert(false, `${itemArr[i]} is in list: `); - }); - } - } - - async verifyDashboardDropdownContainsDividers(labels){ - let labelArr = labels.split(','); - for(let i = 0; i < labelArr.length; i++){ - await this.dbdPage.getdropdownMenuDivider(labelArr[i].trim()).then(async elem => { - assert(true, `${await elem.getText()} is in list`); - }).catch(() => { - assert(false, `${labelArr[i]} is in list`); - }); - } - } - - async clickDashboardRefreshDropdown(){ - await this.clickAndWait(await this.dbdPage.getRefreshRateDropdown()); - } - - async clickDashboardTimeRangeDropdown(){ - await this.clickAndWait(await this.dbdPage.getTimeRangeDropdown()); - } - - async verifyDashboardTimeRangeDropdownSelected(value){ - await this.verifyElementText(await this.dbdPage.getTimeRangeDropdownSelected(), value) - } - - async selectDashboardTimeRange(item){ - await this.dbdPage.getTimeRangeDropdownItem(item).then(async elem => { - await this.scrollElementIntoView(elem).then(async () => { - await this.clickAndWait(elem, async () => { - await this.driver.sleep(1500); //give cells chance to reload - TODO better wait - }); - }); - }); - } - - async clickCreateCellEmpty(){ - //todo wait for buckets to be loaded --- - await this.clickAndWait(await this.dbdPage.getEmptyStateAddCellButton(), async() => { - await this.driver.sleep(1000); /*this.driver.wait( - until.elementLocated(By.css(cellEditOverlay.getBucketSelectSearchSelector().selector)) - );*/ //for some reason wait with until still sometimes overruns subsequent steps - }); - } - - async clickHeaderAddCellButton(){ - await this.clickAndWait(await this.dbdPage.getAddCellButtonHeader(), async() => { - await this.driver.sleep(1000); //see comment above in clickCreateCellEmpty() - }) - } - - async verifyCellNotPresent(name){ - await this.assertNotPresent(await dashboardPage.getCellSelectorByName(name)); - } - - async verifyEmptyGraphMessage(name){ - await this.assertVisible(await this.dbdPage.getCellEmptyGraphMessage(name)); - } - - async verifyEmptyGraphNoResults(name){ - await this.assertVisible(await this.dbdPage.getCellEmptyGraphNoResults(name)); - } - - async verifyCellContainsGraphError(name){ - await this.assertVisible(await this.dbdPage.getCellEmptyGraphError(name)); - } - - async verifyCellContainsGraph(name){ - await this.assertVisible(await this.dbdPage.getCellCanvasAxes(name)); - await this.assertVisible(await this.dbdPage.getCellCanvasLine(name)); - } - - async getCellMetrics(name){ - await this.dbdPage.getCellByName(name).then(async cell => { - await cell.getRect().then(async rect => { - // console.log("DEBUG rect for " + name + " " + JSON.stringify(rect)) - /* eslint-disable no-undef */ - if(typeof __dataBuffer.rect === 'undefined'){ - __dataBuffer.rect = []; - } - __dataBuffer.rect[name] = rect; - //debug why resize not saved - //await influxUtils.signInAxios('admin'); - //let dashboards = await influxUtils.getDashboards(); - //console.log("DEBUG dashboards " + JSON.stringify(dashboards)); - - }); - }); - } - - async getCurrentGraphOfCell(name){ - await this.dbdPage.getCellCanvasAxes(name).then(async canvasAxes => { - if(typeof __dataBuffer.graphCellAxes === 'undefined') { - __dataBuffer.graphCellAxes = []; - } - /* eslint-disable require-atomic-updates */ - __dataBuffer.graphCellAxes[name] = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - // console.log('DEBUG __dataBuffer.graphCellAxes[' + name + "] " + - // __dataBuffer.graphCellAxes[name]); - - await this.dbdPage.getCellCanvasLine(name).then(async canvasLine => { - if(typeof __dataBuffer.graphCellLine === 'undefined') { - __dataBuffer.graphCellLine = []; - } - __dataBuffer.graphCellLine[name] = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - - // console.log('DEBUG __dataBuffer.graphCellLine[' + name + "] " + - // __dataBuffer.graphCellLine[name]); - }); - }); - } - - async verifyCellGraphChange(name){ - - await this.driver.sleep(1000); //troubleshoot canvas update issue - - await this.dbdPage.getCellCanvasAxes(name).then(async canvasAxes => { - let currentAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - await expect(currentAxes).to.not.equal(__dataBuffer.graphCellAxes[name]); - - await this.dbdPage.getCellCanvasLine(name).then(async canvasLine => { - let currentLine = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - await expect(currentLine).to.not.equal(__dataBuffer.graphCellLine[name]); - }); - }); - } - - async verifyCellGraphNoChange(name){ - - await this.driver.sleep(1000); //troubleshoot canvas update issue - - await this.dbdPage.getCellCanvasAxes(name).then(async canvasAxes => { - let currentAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - await expect(currentAxes).to.equal(__dataBuffer.graphCellAxes[name]); - - await this.dbdPage.getCellCanvasLine(name).then(async canvasLine => { - let currentLine = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - await expect(currentLine).to.equal(__dataBuffer.graphCellLine[name]); - }); - }); - - } - - async verifyCellGraphVisible(name){ - await this.assertVisible(await this.dbdPage.getCellCanvasLine(name)); - await this.assertVisible(await this.dbdPage.getCellCanvasAxes(name)); - } - - async compareCellGraphs(name1, name2, equal = true){ - await this.dbdPage.getCellCanvasLine(name1).then(async canvas1 => { - let line1 = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvas1); - await this.dbdPage.getCellCanvasLine(name2).then(async canvas2 => { - let line2 = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvas2); - - if(equal) { - await expect(line1).to.equal(line2); - }else{ - await expect(line1).to.not.equal(line2); - } - }); - }); - } - - async toggleDashboardCellContextMenu(name){ - await this.clickAndWait(await this.dbdPage.getCellContextToggleByName(name), async () => { - await this.driver.wait( - until.elementLocated(By.css(dashboardPage.getCellPopoverContentsSelector().selector)) - ); - }); - } - - async toggle2ndDashboardCellContextMenu(name){ - await this.dbdPage.getCellsByName(name).then( async cells => { - await this.clickAndWait(await cells[1] - .findElement(By.xpath('.//*[@data-testid=\'cell-context--toggle\']')), async () => { - await this.driver.sleep(1000); // todo - better wait sometimes slow to load - }); - }); - } - - async clickDashboardPopOverlayAddNote(){ - await this.clickAndWait(await this.dbdPage.getCellPopoverContentsAddNote(), async () => { - //await this.driver.wait( - //until.elementLocated(By.css(basePage.getPopupBodySelector().selector)) // not working consistently - //); - await this.driver.sleep(1000); //sometimes slow and then overrun by downstream steps - }); - } - - async clickNotePopupCance(){ - await this.clickAndWait(await this.dbdPage.getNotePopupCancel()); - } - - async clickDashboardPopOverlayEditNote(){ - await this.clickAndWait(await this.dbdPage.getcellPopoverContentsEditNote(), async () => { - await this.driver.sleep(1000); - }) - } - - async clickDashboardPopOverlayConfigure(){ - await this.clickAndWait(await this.dbdPage.getCellPopoverContentsConfigure(), async () => { - /*await this.driver.wait( - until.elementLocated(By.css(cellEditOverlay.getTimeMachineOverlay().selector)) - );*/ // this wait not working reliably. so for now use sleep - await this.driver.sleep(1500); // todo better wait - }); - } - - async clickDashboardPopOverlayDelete(){ - await this.clickAndWait(await this.dbdPage.getCellPopoverContentsDelete()); - } - - async clickDashboardPopOverlayDeleteConfirm(){ - await this.clickAndWait(await this.dbdPage.getCellPopoverContentsDeleteConfirm()); - } - - async clickDashboardPopOverlayClone(){ - await this.clickAndWait(await this.dbdPage.getCellPopoverContentsClone()); - } - - async verifyEditNotePopupLoaded(){ - await this.assertVisible(await this.dbdPage.getPopupBody()); - await this.verifyElementContainsText(await this.dbdPage.getPopupTitle(), 'Edit Note'); - await this.assertVisible(await this.dbdPage.getNotePopupCodeMirror()); - await this.assertVisible(await this.dbdPage.getPopupDismiss()); - await this.assertVisible(await this.dbdPage.getNotePopupCancel()); - await this.assertVisible(await this.dbdPage.getNotePopupSave()); - await this.assertVisible(await this.dbdPage.getNotePopupNoDataToggle()); - await this.assertVisible(await this.dbdPage.getNotePopupEditorPreview()); - } - - async verifyMainEditNotePopupLoaded(state){ - await this.assertVisible(await this.dbdPage.getPopupBody()); - await this.verifyElementContainsText(await this.dbdPage.getPopupTitle(), `${state} Note`); - await this.assertVisible(await this.dbdPage.getNotePopupCodeMirror()); - await this.assertVisible(await this.dbdPage.getPopupDismiss()); - await this.assertVisible(await this.dbdPage.getNotePopupCancel()); - await this.assertVisible(await this.dbdPage.getNotePopupSave()); - await this.assertVisible(await this.dbdPage.getNotePopupEditorPreview()); - await this.assertVisible(await this.dbdPage.getNotePopupGuideLink()); - } - - async setCellNotePopupCodeMirrorText(text){ - await this.setCodeMirrorText(await this.dbdPage.getNotePopupCodeMirror(), text); - } - - async verifyCellNotPopupPreviewContains(text){ - await this.dbdPage.getNotePopupEditorPreviewText().then(async elem => { - await expect(await elem.getText()).to.include(text); - }); - } - - async clickCellNotePopupSave(){ - await this.clickAndWait(await this.dbdPage.getPopupSaveSimple(), async () => { - await this.driver.wait( - until.stalenessOf(await this.dbdPage.getPopupOverlay()) - ); - }); - } - - async verifyCellHasNoteIndicator(name){ - await this.assertVisible(await this.dbdPage.getCellNoteByName(name)); - } - - async clickCellNoteIndicator(name){ - await this.clickAndWait(await this.dbdPage.getCellNoteByName(name)); - } - - async verifyContentsOfCellNote(text){ - await this.dbdPage.getNotePopoverContents().then(async contents => { - await expect(await contents.getText()).to.include(text); - }); - } - - async verifyNotePopupMarkdownPreviewContains(tag, content){ - await this.verifyElementText(await this.dbdPage.getNotePopupEditorPreviewTag(tag), content); - }; - - async verifyNoteCellContains(tag,content){ - await this.verifyElementText(await this.dbdPage.getNoteCellMarkdownTag(tag), content); - } - - async clickCellTitle(name){ - await this.clickAndWait(await this.dbdPage.getCellTitle(name)); - } - - async verifyCellNotePopoverNotPresent(){ - await this.assertNotPresent(dashboardPage.getNotePopoverSelector()); - } - - async verifyCellContentPopoverItemEditNote(){ - await this.verifyElementContainsText(await this.dbdPage.getCellPopoverContentsAddNote(), 'Edit Note'); - } - - async verifyCellContentPopoverNotPresent(){ - await this.assertNotPresent(dashboardPage.getCellPopoverContentsSelector()); - } - - async verifyCodeMirrorContainsText(text){ - expect(await this.getCodeMirrorText(await this.dbdPage.getNotePopupCodeMirror())) - .to.include(text); - } - - async clearCellNotePopupCodeMirror(){ - await this.setCodeMirrorText(await this.dbdPage.getNotePopupCodeMirror(), ''); - } - - async verifyCellNotePopupMarkupPreviewNoText(){ - await this.dbdPage.getNotePopupEditorPreviewText().then(async text => { - let strText = await text.getText(); - expect(strText.length).to.equal(0); - }); - } - - async moveDashboardCell(name, deltaCoords){ - //await this.clickAndWait(await this.dbdPage.getCellHandleByName(name)); - await this.dbdPage.getCellHandleByName(name).then( async cell => { - let action = await this.driver.actions(); - let rect = await cell.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let dx = parseInt(deltaCoords.dx); - let dy = parseInt(deltaCoords.dy); - await action - .move({x: x, y: y, duration: 1000}) - .press() - .move({x:x + dx , y: y + dy, duration: 1000}) - .release() - .perform(); - - await this.driver.sleep(1000); - - }); - } - - async verifyCellPositionChange(name, deltaCoords){ - // Use tolerance because of snap to grid feature - let tolerance = 50; //can be +/- 50 px - await this.dbdPage.getCellByName(name).then(async cell => { - let rect = await cell.getRect(); - //console.log("DEBUG rect for " + name + " " + JSON.stringify(rect)) - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let dx = parseInt(deltaCoords.dx); - let dy = parseInt(deltaCoords.dy); - let expx = parseInt(__dataBuffer.rect[name].x) + dx; - let expy = parseInt(__dataBuffer.rect[name].y) + dy; - expect(Math.abs(expx - x )).to.be.below(tolerance); - expect(Math.abs(expy - y )).to.be.below(tolerance); - }); - } - - async resizeDashboardCell(name, deltaSize){ - - await this.dbdPage.getCellResizerByName(name).then(async resizer => { - let action = this.driver.actions(); - let rect = await resizer.getRect(); - //console.log("DEBUG rect " + JSON.stringify(rect)); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - //console.log("DEBUG x:" + x + " y:" + y); - let dw = parseInt(deltaSize.dw); - let dh = parseInt(deltaSize.dh); - await action - .move({x: x, y: y, duration: 1000}) - .press() - .move({x:x + dw , y: y + dh, duration: 1000}) - .release() - .perform(); - await this.driver.sleep(200); //slight wait for animation - await resizer.click(); - - //debug why resize not saved - //await influxUtils.signInAxios('admin'); - //let dashboards = await influxUtils.getDashboards(); - //console.log("DEBUG dashboards " + JSON.stringify(dashboards)); - - - }); - } - - async verifyDashboardCellSizeChange(name, deltaSize){ - // Use tolerance because of snap to grid feature - let tolerance = 50; //can be +/- 50 px - await this.dbdPage.getCellByName(name).then(async cell => { - - //debug why resize not saved - //await influxUtils.signInAxios('admin'); - //let dashboards = await influxUtils.getDashboards(); - //console.log("DEBUG dashboards " + JSON.stringify(dashboards)); - - let rect = await cell.getRect(); - //console.log("DEBUG rect " + JSON.stringify(rect)) - let width = parseInt(rect.width); - let height = parseInt(rect.height); - let dw = parseInt(deltaSize.dw); - let dh = parseInt(deltaSize.dh); - let exph = parseInt(__dataBuffer.rect[name].height) + dh; - let expw = parseInt(__dataBuffer.rect[name].width) + dw; - expect(Math.abs(exph - height )).to.be.below(tolerance); - expect(Math.abs(expw - width )).to.be.below(tolerance); - }); - } - - async hoverGraphOfCell(name){ - await this.dbdPage.getCellCanvasLine(name).then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let centX = parseInt((rect.width / 2) + x); - let centY = parseInt((rect.height / 2) + y); - await action.move({x : centX, y: centY, duration: 1000}) - .perform(); - await this.driver.sleep(200); // todo better wait - let graph update - //await this.dbdPage.getCellHoverBox().then(async box => { - // await this.assertVisible(box); - // console.log("DEBUG got cell hover box"); - //}) - }); - } - - async verifyCellGraphDataPointInfoBox(){ - await this.assertVisible(await this.dbdPage.getCellHoverBox()); - } - - async moveToHorizontalFractionOfGraphCell(fraction, name){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dbdPage.getCellCanvasLine(name).then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt(((rect.width/denom) * numer) + x); - let targetY = parseInt((rect.height / 2) + y); - await action.move({x: targetX, y: targetY, duration: 1000}) - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async dragToHorizontalFractionOfGraphCell(fraction, name){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dbdPage.getCellCanvasLine(name).then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt(((rect.width/denom) * numer) + x); - let targetY = parseInt((rect.height / 2) + y); - await action.press() - .move({x: targetX, y: targetY, duration: 1000}) - .release() - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async moveToVerticalFractionOfGraphCell(fraction, name){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dbdPage.getCellCanvasLine(name).then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt((rect.width/2) + x); - let targetY = parseInt(((rect.height/denom) * numer) + y); - await action.move({x: targetX, y: targetY, duration: 1000}) - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async dragToVerticalFractionOfGraphCell(fraction, name){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dbdPage.getCellCanvasLine(name).then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt((rect.width/2) + x); - let targetY = parseInt(((rect.height/denom) * numer) + y); - await action.press() - .move({x: targetX, y: targetY, duration: 1000}) - .release() - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async clickPointWithinCellByFractions(fracs, name) { - let xfract = {}; - let yfract = {}; - xfract.raw = fracs.x.split('/'); - yfract.raw = fracs.y.split('/'); - xfract.denom = xfract.raw[1]; - xfract.numer = xfract.raw[0]; - yfract.denom = yfract.raw[1]; - yfract.numer = yfract.raw[0]; - await this.dbdPage.getCellCanvasLine(name).then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt(((rect.width/xfract.denom) * xfract.numer) + x); - let targetY = parseInt(((rect.height/yfract.denom) * yfract.numer) + y); - await action.move({x: targetX, y: targetY, duration: 1000}) - .doubleClick() - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async verifyCountCellsNamed(name, ct){ - await this.dbdPage.getCellsByName(name).then(async cells => { - expect(cells.length).to.equal(ct); - - }); - } - - async hoverOverCellErrorIcon(name){ - await this.hoverOver(await this.dbdPage.getCellEmptyGraphErrorIcon(name)); - } - - async verifyEmptyCellErrorPopoverMessage(msg){ - await this.verifyElementContainsText(await this.dbdPage.getEmptyGraphPopoverContents(), msg); - } - - async verifyCellErrorMessage(name, msg){ - await this.verifyElementContainsText(await this.dbdPage.getCellEmptyGraphError(name), msg); - } - - async verifyVariablesButtonActive(){ - await this.verifyElementContainsClass(await this.dbdPage.getVariablesButton(), 'cf-button-secondary'); - } - - async verifyVariablesButtonInactive(){ - await this.verifyElementContainsClass(await this.dbdPage.getVariablesButton(), 'button-default') - } - - async clickValueDropdownOfVar(varname){ - await this.clickAndWait(await this.dbdPage.getVariableValueDropdownButtonForVar(varname)); - } - - async verifyVariableDropdownContents(varname,items){ - let list = items.split(','); - for(let i = 0; i < list.length; i++){ - await this.assertVisible(await this.dbdPage.getVariableValueDropdownItem(varname,list[i].trim())); - } - } - - async verifySlectedValueOfVariable(varname, item){ - await this.verifyElementText(await this.dbdPage.getVariableValueDropdownButtonForVar(varname), item); - } - - async clickItemOfVariableValueDropdown(item, varname){ - await this.clickAndWait(await this.dbdPage.getVariableValueDropdownItem(varname, item)); - } - - async verifyVariableValuesDropdownVisible(varname){ - await this.assertVisible(await this.dbdPage.getVariableValueDropdownButtonForVar(varname)); - } - - async verifyVariableValuesDropdownNotVisible(varname){ - await this.assertNotPresent(await dashboardPage.getVariableValueDropdownButtonForVarSelector(varname)); - } - - async clickVariablesButton(){ - await this.clickAndWait(await this.dbdPage.getVariablesButton()); - } - - async clickDashboardMainAddNote(){ - await this.clickAndWait(await this.dbdPage.getAddNoteButton(), async() => { - await this.driver.sleep(1000); //troubleshoot occasional problems in CircleCI - }); - } - -} - -module.exports = dashboardSteps; diff --git a/e2e/src/steps/dashboards/dashboardsSteps.js b/e2e/src/steps/dashboards/dashboardsSteps.js deleted file mode 100644 index e0e9304e96..0000000000 --- a/e2e/src/steps/dashboards/dashboardsSteps.js +++ /dev/null @@ -1,371 +0,0 @@ -const { expect } = require('chai'); -const path = require('path'); - -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const dashboardsPage = require(__srcdir + '/pages/dashboards/dashboardsPage.js'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -class dashboardsSteps extends influxSteps { - - constructor(driver){ - super(driver); - this.dbdsPage = new dashboardsPage(driver); - } - - async isLoaded(){ - await this.dbdsPage.isLoaded(); - } - - async verifyIsLoaded(){ - this.assertVisible(await this.dbdsPage.getCreateDashboardDropdown()); - this.assertVisible(await this.dbdsPage.getFilterDashboards()); - this.assertVisible(await this.dbdsPage.getSortTypeButton()); - // this.assertVisible(await this.dbdsPage.getModifiedSortButton()); - } - - async clickCreateDashboard(){ - await this.clickAndWait(await this.dbdsPage.getCreateDashboardDropdown()); // todo better wait - } - - async clickCreateDashboardItem(item){ - await this.clickAndWait(await this.dbdsPage.getCreateDashboardItem(item), - async () => { await this.driver.sleep(1000);}); // todo better wait - slow to load? - } - - async clickCreateDashboardEmpty(){ - await this.clickAndWait(await this.dbdsPage.getCreateDashboardDropdownEmpty()); // todo better wait - } - - async verifyEmptyCreateDashboardItems(items){ - let itemsArr = items.split(','); - await this.dbdsPage.getCreateDashboardItems().then( async pgItems => { - for( let i = 0; i < pgItems.length; i++){ - expect(await pgItems[i].getAttribute('id')).to.equal(itemsArr[i].trim()); - } - }); - } - - async verifyEmptyCreateDashboardNotPresent(){ - await this.assertNotPresent(dashboardsPage.getCreateDashboardDropdownEmptySelector()); - } - - async verifyDashboardCardVisible(name){ - await this.assertVisible(await this.dbdsPage.getDashboardCardByName(name)); - } - - async verifyDashboardCardNotPresent(name){ - await this.assertNotPresent(await dashboardsPage.getDashboardCardSelectorByName(name)); - } - - async hoverOVerDashboardCard(name){ - await this.hoverOver(await this.dbdsPage.getDashboardCardByName(name)); - } - - async verifyExportButtonOfCardVisible(name){ - await this.assertVisible(await this.dbdsPage.getDashboardCardExportButton(name)); - } - - async verifyCloneButtonOfCardVisible(name){ - await this.assertVisible(await this.dbdsPage.getDashboardCardCloneButton(name)); - } - - async verifyDeleteButtonOfCardVisible(name){ - await this.assertVisible(await this.dbdsPage.getDashboardCardDeleteButton(name)); - } - - async hoverOverDashboardCardName(name){ - await this.hoverOver(await this.dbdsPage.getDashboardCardName(name)); - } - - async clickDashboardCardName(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardName(name), async () => { - await this.driver.sleep(500); //troubleshoot why dashboard not loaded - }); - } - - async clickDashboardCardNameButton(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardNameButton(name)); - } - - async clearDashboardCardName(name){ - await this.clearInputText(await this.dbdsPage.getDashboardCardNameInput(name)); - } - - async renameDashboardCard(newName, oldName){ - await this.typeTextAndWait(await this.dbdsPage.getDashboardCardNameInput(oldName), newName); - } - - async verifyDashboardCardContainsDescription(name,descr){ - await this.verifyElementContainsText(await this.dbdsPage.getDashboardCardDescription(name), - descr); - } - - async hoverOverDashboardCardDescription(name){ - await this.hoverOver(await this.dbdsPage.getDashboardCardDescription(name)); - } - - async clickDashboardCardEditDescriptionButton(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardDescriptionEdit(name)); - } - - async enterDashboardCardDescription(name,descr){ - await this.typeTextAndWait(await this.dbdsPage.getDashboardCardDescriptionInput(name), descr); - } - - async clickEmptyLabelOfDashboardCard(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardLabelsEmpty(name)); - } - - async clickAddLabelOfDashboardCard(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardAddLabels(name)); - } - - async verifyLabelInDashboardsPopoverIsVisible(label){ - await this.assertVisible(await this.dbdsPage.getAddLabelsPopoverLabel(label)); - } - - async verifyLabelInDashboardsPopoverIsNotPresent(label){ - await this.assertNotPresent(await dashboardsPage.getAddLabelsPopoverLabelSelector(label)); - } - - async enterDashboardLabelsFilter(text){ - await this.typeTextAndWait(await this.dbdsPage.getAddLabelsPopoverFilter(), text); - } - - async verifyDashboardAddLabelsPillCount(count){ - await this.dbdsPage.getAddLabelsLabelPills().then(async pills => { - expect(pills.length).to.equal(parseInt(count)); - }); - } - - async verifyLabelPopoverCreateNewNotPresent(){ - await this.assertNotPresent(await dashboardsPage.getAddLabelsPopoverNewItemSelector()); - } - - async verifyLabelPopoverCreateNewIsVisible(){ - await this.assertVisible(await this.dbdsPage.getAddLabelsPopoverNewItem()); - } - - async clickLabelPopoverCreateNewLabel(){ - await this.clickAndWait(await this.dbdsPage.getAddLabelsPopoverNewItem(), - async () => { await this.driver.sleep(1000); }); //popup slow to load? todo better wait - } - - async verifyDashboardCardHasLabel(name, label){ - await this.assertVisible(await this.dbdsPage.getDashboardCardLabelPill(name, label)); - } - - async clickDashboardCardAddLabel(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardAddLabels(name)); - } - - async hoverDashboardCardLabel(name, label){ - await this.hoverOver(await this.dbdsPage.getDashboardCardLabelPill(name, label)); - } - - async clickDashboardCardRemoveLabel(name,label){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardLabelPillDelete(name, label)); - } - - async verifyDashboardCardLabelsEmptyVisible(name){ - await this.assertVisible(await this.dbdsPage.getDashboardCardLabelsEmpty(name)); - } - - async verifyDashboardCardLabelNotPresent(name, label){ - await this.assertNotPresent(await dashboardsPage.getDashboardCardLabelPillSelector(name, label)); - } - - async verifyDashboardCardsVisible(cards){ - let cardsArr = cards.split(','); - cardsArr.forEach(async cardName => { - await this.assertVisible(await this.dbdsPage.getDashboardCardByName(cardName)); - } ); - } - - async verifyDashboardCardsNotPresent(cards){ - let cardsArr = cards.split(','); - for(let i = 0; i < cardsArr.length; i++){ - await this.assertNotPresent(await dashboardsPage.getDashboardCardSelectorByName(cardsArr[i].trim())); - } - } - - async enterDashboardsCardFilter(term){ - await this.typeTextAndWait(await this.dbdsPage.getFilterDashboards(), term); - } - - async clearDashboardsCardFilter(){ - await this.clearInputText(await this.dbdsPage.getFilterDashboards()); - } - - async verifyImportDashboardPopupVisible(){ - await this.verifyElementContainsText(await this.dbdsPage.getPopupTitle(), 'Import Dashboard'); - //and upload file - await this.assertVisible(await this.dbdsPage.getImportPopupUploadFileRadio()); - //and paste json - await this.assertVisible(await this.dbdsPage.getImportPopupPasteJSONRadio()); - //and dismiss button - await this.assertVisible(await this.dbdsPage.getImportPopupDismiss()); - //and Import json button - await this.assertVisible(await this.dbdsPage.getImportPopupImportJSONButton()); - //and drag and drop form - await this.assertVisible(await this.dbdsPage.getImportPopupFileInput()); - } - - async verifyCreateDashboardFromTemplatePopupVisible(){ - await this.verifyElementContainsText(await this.dbdsPage.getPopupTitle(), 'Create Dashboard from a Template'); - //dismiss - await this.assertVisible(await this.dbdsPage.getFromTemplatePopupDismiss()); - //cancel - await this.assertVisible(await this.dbdsPage.getFromTemplatePopupCancel()); - //create Dashboard button - await this.assertVisible(await this.dbdsPage.getFromTemplatePopupCreateDBoard()); - //templates list - await this.assertVisible(await this.dbdsPage.getFromTemplatePopupTemplateList()); - //templates list item - await this.assertVisible(await this.dbdsPage.getFromTemplatePopupTemplateItem('System')); - //template panel - preview - await this.assertVisible(await this.dbdsPage.getFromTemplatePopupTemplatePanel()); - } - - async uploadImportDashboardPopupFile(path2file){ - await this.dbdsPage.getImportPopupDragNDropFile().then(async elem => { - await elem.sendKeys(process.cwd() + '/' + path2file).then(async () => { - await this.delay(200); //debug wait - todo better wait - }); - }); - } - - async verifyImportPopupUploadSuccess(){ - await this.verifyElementContainsClass(await this.dbdsPage.getImportPopupFileInputHeader(), 'selected'); - } - - async verifyImportPopupUploadFilename(filepath){ - let fp = path.parse(filepath); - await this.verifyElementContainsText(await this.dbdsPage.getImportPopupFileInputHeader(), fp.base); - } - - async clickImportDashboardButton(){ - await this.clickAndWait(await this.dbdsPage.getImportPopupImportJSONButton()); - } - - async clickImportDashboardPasteJSON(){ - await this.clickAndWait(await this.dbdsPage.getImportPopupPasteJSONRadio()); - } - - async verifyImportDashboardFileUploadNotPresent(){ - await this.assertNotPresent(await dashboardsPage.getImportPopupFileInputSelector()); - } - - async pasteFileContentsImportDashboardTextarea(filepath){ - let contents = await influxUtils.readFileToBuffer(filepath); - //console.log("DEBUG file contents:\n " + contents ); - await this.typeTextAndWait(await this.dbdsPage.getImportPopupJSONTextarea(), contents); - } - - async clickFromTemplatePopupCancel(){ - await this.clickAndWait(await this.dbdsPage.getFromTemplatePopupCancel()); - } - - async clickFromTemplatePopupTemplateItem(item){ - await this.clickAndWait(await this.dbdsPage.getFromTemplatePopupTemplateItem(item)); - } - - async verifyFromTemplatePreviewCellVisible(name){ - await this.assertVisible(await this.dbdsPage.getfromTemplatePopupPreviewCell(name)); - } - - async verifyFromTemplatePopupCreateDisabled(){ - await this.verifyElementDisabled(await this.dbdsPage.getFromTemplatePopupCreateDBoard()); - } - - async clickDashboardFromTemplateCreate(){ - await this.clickAndWait(await this.dbdsPage.getFromTemplatePopupCreateDBoard()); - } - - async verifyDashboardSortOrder(dBoards){ - let dbArray = dBoards.split(','); - await this.dbdsPage.getDashboardCardNames().then(async names => { - for(let i = 0; i < names.length; i++){ - expect(await names[i].getText()).to.equal(dbArray[i]); - } - }); - } - - async clickSortDashboardsListItem(item){ - await this.clickAndWait(await this.dbdsPage.getSortTypeItem(item.toLowerCase() - .replace(" ", "-"))); - } - - async clickSortDashboardsByType(){ - await this.clickAndWait(await this.dbdsPage.getSortTypeButton()); - } - - async clickDashboardCardDelete(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardDeleteButton(name)); - } - - async clickDashboardCardDeleteConfirm(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardDeleteConfirm(name)); - } - - async clickDashboardCardClone(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardCloneButton(name)); - } - - async clickDashboardCardCloneConfirm(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardCloneConfirm(name)); - } - - async clickDashboardCardExport(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardExportButton(name)); - } - - async clickDashboardCardExportConfirm(name){ - await this.clickAndWait(await this.dbdsPage.getDashboardCardExportConfirm(name), - async () => { await this.driver.sleep(1000); }); //slow to load? - } - - async verifyExportDashboardPopupLoaded(){ - await this.verifyElementContainsText(await this.dbdsPage.getPopupTitle(), 'Export Dashboard'); - //dismiss - await this.assertVisible(await this.dbdsPage.getExportPopupDismiss()); - //codeMirror - await this.assertVisible(await this.dbdsPage.getExportPopupCodeMirror()); - //DownloadJSON - await this.assertVisible(await this.dbdsPage.getExportPopupDownloadJSON()); - //AsTemplate - await this.assertVisible(await this.dbdsPage.getExportPopupSaveAsTemplate()); - //Copy2Clipboard - await this.assertVisible(await this.dbdsPage.getexportPopupCopyToClipboard()); - } - - async clickExportDashboardPopupDismiss(){ - await this.clickAndWait(await this.dbdsPage.getExportPopupDismiss()); - } - - async clickExportDashboardDownloadJSON(filePath){ - if(__config.sel_docker){ - console.warn('File export not supported without shared memory'); - await this.clickAndWait(await this.dbdsPage.getExportPopupDownloadJSON()); - return; - } - await this.clickAndWait(await this.dbdsPage.getExportPopupDownloadJSON(), - async () => {await influxUtils.waitForFileToExist(filePath); }); //wait for download to complete - } - - async clickExportDashboardSaveAsTemplate(){ - await this.clickAndWait(await this.dbdsPage.getExportPopupSaveAsTemplate()); - } - - async clickExportDashboardCopyToClipboard(){ - await this.clickAndWait(await this.dbdsPage.getexportPopupCopyToClipboard()); - } - - async clickDashboardsFilterInput(){ - await this.clickAndWait(await this.dbdsPage.getFilterDashboards()); - } - -} - -module.exports = dashboardsSteps; - diff --git a/e2e/src/steps/dataExplorer/dataExplorerSteps.js b/e2e/src/steps/dataExplorer/dataExplorerSteps.js deleted file mode 100644 index db141bb8f8..0000000000 --- a/e2e/src/steps/dataExplorer/dataExplorerSteps.js +++ /dev/null @@ -1,471 +0,0 @@ -const expect = require('chai').expect; - -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const dataExplorerPage = require(__srcdir + '/pages/dataExplorer/dataExplorerPage.js'); - -class dataExplorerSteps extends influxSteps { - - constructor(driver) { - super(driver); - this.dePage = new dataExplorerPage(driver); - } - - async isLoaded() { - await this.dePage.isLoaded(); - } - - async verifyIsLoaded() { - this.assertVisible(await this.dePage.getTimeLocaleDropdown()); - this.assertVisible(await this.dePage.getGraphTypeDropdown()); - this.assertVisible(await this.dePage.getCustomizeGraphButton()); - this.assertVisible(await this.dePage.getSaveAsButton()); - this.assertVisible(await this.dePage.getViewArea()); - this.assertVisible(await this.dePage.getViewRawToggle()); - this.assertVisible(await this.dePage.getAutoRefreshDropdown()); - this.assertVisible(await this.dePage.getTimeRangeDropdown()); - this.assertVisible(await this.dePage.getSubmitQueryButton()); - } - - async chooseBucket(bucket) { - await this.dePage.getBucketSelector(await this.dePage.getItemFromSelectorList(bucket).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - })) - } - - /* - async chooseMeasurement(measurement, index) { - await this.dePage.getBuilderCardByIndex(await this.dePage.getItemFromSelectorList(measurement).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }), index) - } - */ - - async chooseItemFromBuilderCard(measurement, index) { - let card = await this.dePage.getBuilderCardByIndex(parseInt(index)); - await this.dePage.getItemFromSelectorList(measurement).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }) - } - - async clickQuerySubmitButton() { - await this.dePage.getSubmitQueryButton().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }) - } - - async verifyGraphVisible(){ - await this.assertVisible(await this.dePage.getGraphCanvas()); - } - - async hoverOverGraph(){ - await this.dePage.getCanvasLine().then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let centX = parseInt((rect.width / 2) + x); - let centY = parseInt((rect.height / 2) + y); - await action.move({x : centX, y: centY, duration: 1000}) - .perform(); - await this.driver.sleep(200); // todo better wait - let graph update - //await this.dbdPage.getCellHoverBox().then(async box => { - // await this.assertVisible(box); - // console.log("DEBUG got cell hover box"); - //}) - }); - } - - async verifyGraphDataPointInfoBox(){ - await this.assertVisible(await this.dePage.getGraphHoverLine()); - } - - - - - - - async getCurrentGraph(){ - await this.dePage.getCanvasAxes().then(async canvasAxes => { - if(typeof __dataBuffer.graphAxes === 'undefined') { - __dataBuffer.graphAxes = []; - } - /* eslint-disable require-atomic-updates */ - __dataBuffer.graphAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - // console.log('DEBUG __dataBuffer.graphCellAxes[' + name + "] " + - // __dataBuffer.graphCellAxes[name]); - - await this.dePage.getCanvasLine().then(async canvasLine => { - if(typeof __dataBuffer.graphLine === 'undefined') { - __dataBuffer.graphLine = []; - } - __dataBuffer.graphLine = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - - // console.log('DEBUG __dataBuffer.graphCellLine[' + name + "] " + - // __dataBuffer.graphCellLine[name]); - }); - }); - } - - async verifyGraphChange(){ - - await this.driver.sleep(1000); //troubleshoot canvas update issue - - await this.dePage.getCanvasAxes().then(async canvasAxes => { - let currentAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - await expect(currentAxes).to.not.equal(__dataBuffer.graphAxes); - - await this.dePage.getCanvasLine().then(async canvasLine => { - let currentLine = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - await expect(currentLine).to.not.equal(__dataBuffer.graphLine); - }); - }); - } - - async moveToHorizontalFractionOfGraph(fraction){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dePage.getCanvasLine().then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt(((rect.width/denom) * numer) + x); - let targetY = parseInt((rect.height / 2) + y); - await action.move({x: targetX, y: targetY, duration: 1000}) - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async dragToHorizontalFractionOfGraph(fraction){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dePage.getCanvasLine().then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt(((rect.width/denom) * numer) + x); - let targetY = parseInt((rect.height / 2) + y); - await action.press() - .move({x: targetX, y: targetY, duration: 1000}) - .release() - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async clickPointWithinGraphByFractions(fracs, name) { - let xfract = {}; - let yfract = {}; - xfract.raw = fracs.x.split('/'); - yfract.raw = fracs.y.split('/'); - xfract.denom = xfract.raw[1]; - xfract.numer = xfract.raw[0]; - yfract.denom = yfract.raw[1]; - yfract.numer = yfract.raw[0]; - await this.dePage.getCanvasLine(name).then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt(((rect.width/xfract.denom) * xfract.numer) + x); - let targetY = parseInt(((rect.height/yfract.denom) * yfract.numer) + y); - await action.move({x: targetX, y: targetY, duration: 1000}) - .doubleClick() - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async moveToVerticalFractionOfGraph(fraction){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dePage.getCanvasLine().then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt((rect.width/2) + x); - let targetY = parseInt(((rect.height/denom) * numer) + y); - await action.move({x: targetX, y: targetY, duration: 1000}) - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async dragToVerticalFractionOfGraph(fraction){ - let fract = fraction.split('/'); - let denom = fract[1]; - let numer = fract[0]; - await this.dePage.getCanvasLine().then(async canvas => { - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let targetX = parseInt((rect.width/2) + x); - let targetY = parseInt(((rect.height/denom) * numer) + y); - await action.press() - .move({x: targetX, y: targetY, duration: 1000}) - .release() - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }); - } - - async clickRefreshGraphButton() { - await this.dePage.getRefreshGraphButton().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }) - } - - - - - async clickRefreshDropdownPaused(){ - await this.dePage.getRefreshDropdownPaused().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async clickRefreshDropdownActive(){ - await this.dePage.getRefreshDropdownActive().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async selectRefreshDropdownItem(item){ - await this.dePage.getRefreshDropdownItem(item).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async clickAddQueryButton(){ - await this.dePage.getAddQueryButton().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async rightClickQueryTabTitle(title) { - await this.dePage.getQueryTabByName(title).then(async elem => { - let action = this.driver.actions(); - - await action.contextClick(elem).perform(); - }); - } - - async clickQueryTabTitle(title) { - await this.dePage.getQueryTabByName(title).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async selectQueryTabMenuItem(item){ - await this.dePage.getQueryTabMenuItem(item).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async setQueryTabName(name){ - await this.dePage.getQueryTabNameInput().then(async elem => { - await this.driver.sleep(200); - //await elem.clear(); - await elem.sendKeys(name); - }); - } - - async clickScriptEditorButton(){ - await this.dePage.getScriptEditorButton().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async pasteIntoScriptEditor(text){ - await this.setMonacoEditorText(await this.dePage.getScriptMonacoEditor(), text); - } - - async clickViewTypeDropdown(){ - await this.clickAndWait(await this.dePage.getViewTypeDropdown()); - } - - async selectViewType(type){ - await this.dePage.getViewType(type).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async verifySingleStatTextVisible(){ - await this.assertVisible(await this.dePage.getSingleStatText()); - } - - async clickViewRawDataToggle(){ - await this.clickAndWait(await this.dePage.getRawDataToggle()); - } - - async verifyRawDataTableVisible(){ - await this.assertVisible(await this.dePage.getRawDataTable()); - } - - async clickTimeRangeDropdown(){ - await this.clickAndWait(await this.dePage.getTimeRangeDropdown()); - } - - async selectTimeRangeDropdownItem(item){ - await this.clickAndWait(await this.dePage.getTimeRangeDropdownItem(item)); - } - - async searchFunction(funct){ - await this.dePage.getFunctionSearchInput().then(async elem => { - //await elem.clear(); - await elem.sendKeys(funct); - }); - } - - async selectFunctionFromList(funct){ - await this.clickAndWait(await this.dePage.getSelectorListFunction(funct)); - } - - async clickSaveAsButton(){ - await this.clickAndWait(await this.dePage.getSaveAsButton()); - } - - async verifySaveAsOverlayVisible(){ - await this.assertVisible(await this.dePage.getSaveAsOverlayHeader()); - } - - async clickTargetDashboardDropdown(){ - await this.clickAndWait(await this.dePage.getTargetDashboardDropdown()); - } - - async selectTargetDashboardDropdownItem(){ - await this.clickAndWait(await this.dePage.getTargetDashboardDropdownItem()); - } - - async setNewDashboardName(name){ - await this.dePage.getNewDashboardNameInput().then(async elem => { - //await elem.clear(); //clear() doesn't work properly - await this.clearInputText(await this.dePage.getNewDashboardNameInput()); - await elem.sendKeys(name); - }); - } - - async setCellName(name){ - await this.dePage.getCellNameInput().then(async elem => { - await this.clearInputText(await this.dePage.getCellNameInput()); - await elem.sendKeys(name); - }); - } - - async clickSaveAsDashboardCellButton(){ - await this.clickAndWait(await this.dePage.getSaveAsDashboardCellButton()); - } - - async clickSaveAsPopupTab(tab, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); }){ - await this.clickAndWait(await this.getSaveAsPopupTab(tab), wait); - } - - async getSaveAsPopupTab(tab){ - let elem = undefined; - switch(tab.toLowerCase()){ - case 'dashboard cell': - elem = await this.dePage.getSaveAsPopupTabCell(); - break; - case 'task': - elem = await this.dePage.getSaveAsPopupTabTask(); - break; - case 'variable': - elem = await this.dePage.getSaveAsPopupTabVar(); - break; - default: - throw `Unknown menu item ${item}`; - } - - return elem; - } - - async setTaskName(name){ - await this.dePage.getTaskNameInput().then(async elem => { - await this.clearInputText(await this.dePage.getTaskNameInput()); - await elem.sendKeys(name); - }); - } - - async setTaskInterval(interval){ - await this.dePage.getTaskIntervalInput().then(async elem => { - await this.clearInputText(await this.dePage.getTaskIntervalInput()); - await elem.sendKeys(interval); - }); - } - - async setTaskOffset(offset){ - await this.dePage.getTaskOffsetInput().then(async elem => { - await this.clearInputText(await this.dePage.getTaskOffsetInput()); - await elem.sendKeys(offset); - }); - } - - async clickSaveAsTaskButton(){ - await this.clickAndWait(await this.dePage.getSaveAsTaskButton()); - } - - async setVariableName(name){ - await this.dePage.getVariableNameInput().then(async elem => { - await elem.clear(); - await elem.sendKeys(name); - }); - } - - async clickSaveAsVariableButton(){ - //await this.clickAndWait(await this.dePage.getSaveAsVariableButton()); - - await this.dePage.getSaveAsVariableButton().then(async elem => { - await this.clickAndWait(await this.dePage.getSaveAsVariableButton()); - }); - } - - - -} - -module.exports = dataExplorerSteps; diff --git a/e2e/src/steps/home/homeSteps.js b/e2e/src/steps/home/homeSteps.js deleted file mode 100644 index 642fa726c9..0000000000 --- a/e2e/src/steps/home/homeSteps.js +++ /dev/null @@ -1,79 +0,0 @@ -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const homePage = require(__srcdir + '/pages/home/homePage.js'); -const { By } = require('selenium-webdriver'); - -class homeSteps extends influxSteps { - - constructor(driver){ - super(driver); - this.homePage = new homePage(driver); - } - - async isLoaded(){ - await this.homePage.isLoaded(); - } - - async verifyIsLoaded(){ - this.assertVisible(await this.homePage.getLogoutButton()); - this.assertVisible(await this.homePage.getGetStartedDataCollect()); - this.assertVisible(await this.homePage.getGetStartedDashboard()); - this.assertVisible(await this.homePage.getGetStartedAlerting()); - this.assertVisible(await this.homePage.getTutorialsList()); - this.assertVisible(await this.homePage.getUsefulLinksList()); - this.assertVisible(await this.homePage.getTutorialLinkByText('Get Started with Flux')); - this.assertVisible(await this.homePage.getUsefulLinkByText('Documentation')); - } - - async clickLogout(){ - await this.homePage.getLogoutButton().then(async btn => { - await btn.click(); - }); - } - - async clickQuickStartPanel(title){ - switch(title.toLowerCase()){ - case 'data collector': - await (await this.homePage.getDataCollectButton()).click(); - break; - case 'dashboard': - await (await this.homePage.getDashboardButton()).click(); - break; - case 'alerting': - await (await this.homePage.getAlertingButton()).click(); - break; - default: - throw `Unknown Quick Start Panel: ${title}`; - } - } - - async verifyDbdPanelDashboard(dbdName){ - this.homePage.getDashboardsList().then(async elem => { - await elem.findElement(By.xpath(`.//a[text() = '${dbdName}']`)).then(async link => { - await this.assertVisible(link); - }); - }); - } - - async clickDbdPanelDashboard(dbdName){ - await this.homePage.getDashboardsList().then(async elem => { - await elem.findElement(By.xpath(`.//a[text() = '${dbdName}']`)).then(async link => { - await link.click(); - }); - }); - } - - async verifyDashboardLinksInPanel(links){ - let linksArr = links.split(','); - for(let i = 0; i < linksArr.length; i++){ - await this.assertVisible(await this.homePage.getDashboardLink(linksArr[i].trim())); - } - } - - async clickDashboardLinkFromPanel(link){ - await this.clickAndWait(await this.homePage.getDashboardLink(link)); - } - -} - - -module.exports = homeSteps; diff --git a/e2e/src/steps/influx/influxSteps.js b/e2e/src/steps/influx/influxSteps.js deleted file mode 100644 index 682fd582a5..0000000000 --- a/e2e/src/steps/influx/influxSteps.js +++ /dev/null @@ -1,173 +0,0 @@ -//const assert = require('chai').assert; -const expect = require('chai').expect; -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const influxPage = require(__srcdir + '/pages/influxPage.js'); - -class influxSteps extends baseSteps { - - constructor(driver){ - super(driver); - this.influxPage = new influxPage(driver); - } - - async isLoaded(){ - await this.influxPage.isLoaded(); - } - - async verifyIsLoaded(){ - this.assertVisible(await this.influxPage.getNavMenu()); - this.assertVisible(await this.influxPage.getMenuHome()); - this.assertVisible(await this.influxPage.getMenuExplorer()); - this.assertVisible(await this.influxPage.getMenuDashboards()); - this.assertVisible(await this.influxPage.getMenuTasks()); - this.assertVisible(await this.influxPage.getMenuSettings()); - //this.assertVisible(await this.influxPage.getMenuFeedback()); - } - - async getNavMenuElem(item){ - let elem = undefined; - switch(item.toLowerCase()){ - case 'home': - elem = await this.influxPage.getMenuHome(); - break; - case 'home:heading': - elem = await this.influxPage.getMenuHomeHeading(); - break; - case 'home:neworg': - elem = await this.influxPage.getMenuHomeNewOrg(); - break; - case 'home:logout': - elem = await this.influxPage.getMenuHomeLogout(); - break; - case 'explorer': - elem = await this.influxPage.getMenuExplorer(); - break; - case 'dashboards': - elem = await this.influxPage.getMenuDashboards(); - break; - case 'tasks': - elem = await this.influxPage.getMenuTasks(); - break; - case 'settings': - elem = await this.influxPage.getMenuSettings(); - break; - // case 'feedback': - // elem = await this.influxPage.getMenuFeedback(); - // break; - case 'alerting': - elem = await this.influxPage.getNavMenuAlerting(); - break; - case 'loaddata': - elem = await this.influxPage.getMenuLoadData(); - // await this.driver.executeScript('arguments[0].style.border=\'3px solid red\'', elem); - break; - case 'organization': - elem = await this.influxPage.getNavMenuOrg(); - break; - case 'user': - elem = await this.influxPage.getNavMenuUser(); - break; - default: - throw `Unknown menu item ${item}`; - } - - return elem; - } - - async getUserMenuElem(item){ - let elem = undefined; - switch(item){ - case 'switchOrg': - elem = await this.influxPage.getUserMenuItem('switch-orgs'); - break; - case 'createOrg': - elem = await this.influxPage.getUserMenuItem('create-orgs'); - break; - case 'logout': - elem = await this.influxPage.getUserMenuItem('logout'); - break; - default: - throw `Unknown menu item ${item}`; - } - - return elem; - } - - async hoverNavMenu(item){ - await this.hoverOver(await this.getNavMenuElem(item)); - } - - async verifySubMenuItems(item, state = 'hidden'){ - if(state === 'hidden'){ - this.assertNotVisible(await this.getNavMenuElem(item)); - }else if(state === 'visible'){ - this.assertVisible(await this.getNavMenuElem(item)); - }else{ - throw `unknown menu state ${state}`; - } - } - - async verifyUserMenuItems(item, state = 'hidden'){ - if(state === 'hidden'){ - this.assertNotVisible(await this.getUserMenuElem(item)); - }else if(state === 'visible'){ - this.assertVisible(await this.getUserMenuElem(item)); - }else{ - throw `unknown menu state ${state}`; - } - } - - async clickMenuItem(item, - wait = async () => { await this.driver.sleep((await this.driver.manage().getTimeouts()).implicit/20); }){ - await this.clickAndWait(await this.getNavMenuElem(item), wait); - } - - async clickUserMenuItem(item){ - await this.clickAndWait(await this.getUserMenuElem(item.toLowerCase())); - } - - async clickSubMenuItem(item, - wait = async () => { await this.driver.sleep(1000); }){ - if(item.toLowerCase() === 'dashboards'){//troubleshoot issue in circleci - await this.driver.sleep(1000); //wait a second for page to load - await this.clickAndWait(await this.influxPage.getSubItemByText(item), async () => { - //N.B. sometimes page will have no cells - so waiting for cells won't always work - //However CircleCI issue is that cells are not showing up - await this.driver.sleep(3000); - }); - - }else { - await this.clickAndWait(await this.influxPage.getSubItemByText(item), wait); - } - } - - async verifyVisibilityNavItemByText(text, visible = true){ - if(visible) { - await this.assertVisible(await this.influxPage.getSubItemByText(text)); - }else{ - await this.assertNotVisible(await this.influxPage.getSubItemByText(text)); - } - } - - async verifyHeaderContains(text, page){ - await this.influxPage.getPageHeader(page).then(async elem => { - await elem.getText().then(async elTxt => { - expect(elTxt).to.include(text); - }); - }); - } - - async verifyFeedbackLinkContains(text){ - await this.getNavMenuElem('feedback').then(async elem => { - await elem.findElement({xpath: './..'}).then(async el2 => { //the getNavMenuElem method uses span inside a tag - await el2.getAttribute('href').then(async attrib =>{ - expect(attrib).to.include(text); - }); - }); - }); - } - - -} - -module.exports = influxSteps; diff --git a/e2e/src/steps/loadData/bucketsSteps.js b/e2e/src/steps/loadData/bucketsSteps.js deleted file mode 100644 index 2468cffa20..0000000000 --- a/e2e/src/steps/loadData/bucketsSteps.js +++ /dev/null @@ -1,683 +0,0 @@ -const { expect, assert } = require('chai'); -const { By, until } = require('selenium-webdriver'); - -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const bucketsTab = require(__srcdir + '/pages/loadData/bucketsTab.js'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -let durationsMap = new Map(); -durationsMap.set('1h', '1 hour'); -durationsMap.set('6h', '6 hours'); -durationsMap.set('12h', '12 hours'); -durationsMap.set('24h', '1 days'); -durationsMap.set('48h', '2 days'); -durationsMap.set('72h', '3 days'); -durationsMap.set('7d', '7 days'); -durationsMap.set('14d', '14 days'); -durationsMap.set('30d', '30 days'); -durationsMap.set('90d', '90 days'); -durationsMap.set('1y', '365 days'); - -class bucketsSteps extends baseSteps { - - constructor(driver){ - super(driver); - this.bucketsTab = new bucketsTab(driver); - } - - async isLoaded(){ - await this.bucketsTab.isTabLoaded(); - } - - async verifyOrderByName(bucketNames){ - let namesArray = bucketNames.split(','); - await this.bucketsTab.getBucketCards().then(async cards => { - for( let i = 0; i < cards.length; i++){ - let cardName = await cards[i].findElement(By.xpath('.//span[contains(@class,\'cf-resource-name--text\')]/span')); - let cardText = await cardName.getText(); - if(namesArray[i].toUpperCase() === 'DEFAULT'){ - expect(cardText).to.equal(__defaultUser.bucket); - }else { - expect(cardText).to.equal(namesArray[i]); - } - } - }); - } - - async verifyBucketNotListedByName(name){ - await this.assertNotPresent(await bucketsTab.getBucketCardSelectorByName(name)); - } - - async clickCreateBucket(){ - await this.clickAndWait(await this.bucketsTab.getCreateBucketBtn()); //todo better wait - /*await this.bucketsTab.getCreateBucketBtn().then(async button => { - await button.click(); - }); */ - } - - async verifyCreateBucketPopup(){ - await this.assertVisible(await this.bucketsTab.getPopupContainer()); - await this.assertVisible(await this.bucketsTab.getPopupTitle()); - await this.assertVisible(await this.bucketsTab.getPopupInputName()); - await this.assertVisible(await this.bucketsTab.getPopupRetentionNever()); - await this.assertVisible(await this.bucketsTab.getPopupRetentionIntervals()); - await this.assertVisible(await this.bucketsTab.getPopupCancelButton()); - await this.assertVisible(await this.bucketsTab.getPopupDismissButton()); - await this.assertVisible(await this.bucketsTab.getPopupCreateButton()); - } - - async verifyEditBucketPopup(){ - await this.assertVisible(await this.bucketsTab.getPopupContainer()); - await this.assertVisible(await this.bucketsTab.getPopupTitle()); - await this.assertVisible(await this.bucketsTab.getPopupInputName()); - await this.assertVisible(await this.bucketsTab.getPopupRetentionNever()); - await this.assertVisible(await this.bucketsTab.getPopupRetentionIntervals()); - await this.assertVisible(await this.bucketsTab.getPopupCancelButton()); - await this.assertVisible(await this.bucketsTab.getPopupDismissButton()); - await this.assertVisible(await this.bucketsTab.getPopupSaveChanges()); - } - - async verifyCreateBucketPopupNotPresent(){ - await this.assertNotPresent(await bucketsTab.getPopupContainerSelector()); - await this.assertNotPresent(await bucketsTab.getPopupTitleSelector()); - } - - async verifyRPIntervalControlsNotPresent(){ - // N.B. Interval controls replaced with dropdown 2019-09-11 - //await this.assertNotPresent(await bucketsTab.getPopupRPIntervalControlsSelector()); - await this.assertNotPresent(await bucketsTab.getPopupRPDurationSelectorButtonSelector()); - } - - async verifyRPIntervalControlsPresent(){ - // N.B. Interval controls replaced with dropdown 2019-09-11 - //await this.assertVisible(await this.bucketsTab.getPopupRPIntevalControls()); - await this.assertVisible(await this.bucketsTab.getPopupRPDurationSelectorButton()); - } - - async clickPopupRPDurationSelectorButton(){ - await this.bucketsTab.getPopupRPDurationSelectorButton().then(async btn => { - await btn.click().then(async () => { - await this.driver.sleep(500); //todo implement better wait - }); - }); - } - - async verifyCreateBucketCreateButtonEnabled(enabled){ - await expect(await (await this.bucketsTab.getPopupCreateButton()).isEnabled()).to.equal(enabled); - } - - async verifyNameInputEnabled(enabled){ - await expect(await (await this.bucketsTab.getPopupInputName()).isEnabled()).to.equal(enabled); - } - - async verifyActiveRetentionPolicyButton(rp){ - await this.driver.findElement(By.css(`[data-testid=retention-${rp}--button]`)) - .then(async elem => { - await elem.getAttribute('class').then( async elemClass => { - await expect(elemClass).to.include('active'); - }); - }); - } - - async verifyInactiveRetentionPolicyButton(rp){ - await this.driver.findElement(By.css(`[data-testid=retention-${rp}--button]`)) - .then(async elem => { - await elem.getAttribute('class').then( async elemClass => { - await expect(elemClass).to.not.include('active'); - }); - }); - } - - async verifyPopupHelpText(text){ - await this.bucketsTab.getPopupHelpText().then(async elem => { - await elem.getText().then(async elText => { - expect(elText).to.include(text); - }); - }); - } - - async clickRetentionPolicyButton(rp){ - await this.driver.findElement(By.css(`[data-testid=retention-${rp}--button]`)) - .then(async elem => { - await elem.click(); - }); - } - - async dismissBucketPopup(){ - - await this.bucketsTab.getPopupDismissButton().then(async btn => { - await btn.click().then( async () => { - await this.driver.wait(await this.bucketsTab - .getUntilElementNotPresent(bucketsTab.getPopupContainerSelector())); - await this.driver.wait(await this.bucketsTab - .getUntilElementNotPresent(bucketsTab.getPopupTitleSelector())); - }); - }); - } - - async cancelBucketPopup(){ - await this.bucketsTab.getPopupCancelButton().then(async btn => { - await btn.click().then(async() => { - await this.driver.wait(await this.bucketsTab - .getUntilElementNotPresent(bucketsTab.getPopupContainerSelector())); - await this.driver.wait(await this.bucketsTab - .getUntilElementNotPresent(bucketsTab.getPopupTitleSelector())); - }); - }); - } - - async setBucketName(name){ - await this.bucketsTab.getPopupInputName().then(async elem => { - await elem.clear(); - await elem.sendKeys(name); - }); - } - - async enterIntervalValue(amount, unit){ - switch(unit.toLowerCase()){ - case 'seconds': - case 'second': - await this.bucketsTab.getPopupRPSecondsInput().then(async elem => { - await elem.sendKeys(amount); - }); - break; - case 'minutes': - case 'minute': - await this.bucketsTab.getPopupRPMinutesInput().then(async elem => { - await elem.sendKeys(amount); - }); - break; - case 'hours': - case 'hour': - await this.bucketsTab.getPopupRPHoursInput().then(async elem => { - await elem.sendKeys(amount); - }); - break; - case 'days': - case 'day': - await this.bucketsTab.getPopupRPDaysInput().then(async elem => { - await elem.sendKeys(amount); - }); - break; - default: - throw `unknown interval unit ${unit}`; - } - } - - //Replaces above 2019-09-11 - async clickRPSelectorValue(rp){ - await this.bucketsTab.getPopupRPDurationSelectorItem(rp).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - - async clearAllRetentionPolicyIntervals(){ - await this.bucketsTab.getPopupRPSecondsInput().then(async elem => { - await elem.clear(); - await elem.sendKeys('0'); - }); - - await this.bucketsTab.getPopupRPMinutesInput().then(async elem => { - await elem.clear(); - await elem.sendKeys('0'); - }); - - await this.bucketsTab.getPopupRPHoursInput().then(async elem => { - await elem.clear(); - await elem.sendKeys('0'); - }); - - await this.bucketsTab.getPopupRPDaysInput().then(async elem => { - await elem.clear(); - await elem.sendKeys('0'); - }); - } - - async verifyIntervalValue(value, unit){ - switch(unit.toLowerCase()){ - case 'seconds': - case 'second': - await this.bucketsTab.getPopupRPSecondsInput().then(async elem => { - await elem.getAttribute('value').then(async elVal => { - expect(parseInt(elVal)).to.equal(parseInt(value)); - }); - }); - break; - case 'minutes': - case 'minute': - await this.bucketsTab.getPopupRPMinutesInput().then(async elem => { - await elem.getAttribute('value').then(async elVal => { - expect(parseInt(elVal)).to.equal(parseInt(value)); - }); - }); - break; - case 'hours': - case 'hour': - await this.bucketsTab.getPopupRPHoursInput().then(async elem => { - await elem.getAttribute('value').then(async elVal => { - expect(parseInt(elVal)).to.equal(parseInt(value)); - }); - }); - break; - case 'days': - case 'day': - await this.bucketsTab.getPopupRPDaysInput().then(async elem => { - await elem.getAttribute('value').then(async elVal => { - expect(parseInt(elVal)).to.equal(parseInt(value)); - }); - }); - break; - default: - throw `unknown interval unit ${unit}`; - } - } - - async clickCreatePopupCreate(){ - await this.bucketsTab.getPopupCreateButton().then( async btn => { - await btn.click(); - await this.driver.sleep(3000); - }); - } - - async verifyFormErrorMessageContains(msg){ - await this.bucketsTab.getPopupFormError().then(async elem => { - await elem.getText().then(async text => { - expect(text).to.include(msg); - }); - }); - } - - async verifyFormErrorMessageNotPresent(){ - await this.assertNotPresent(await bucketsTab.getPopupFormErrorSelector()); - } - - async verifyBucketInListByName(name){ - try{ - await this.bucketsTab.getBucketCardByName(name); - }catch(err){ - assert.fail(`Failed to locate card named ${name} in current list`); - } - - /*await this.bucketsTab.getBucketCards().then(async cards => { - for(let i = 0; i < cards.length; i++){ - let crd_nm = await cards[i].findElement(By.xpath('.//span[contains(@class,\'cf-resource-name--text\')]/span')); - if((await crd_nm.getText()) === name){ - assert(true, `matched card with name ${name}`); - return; - } - } - assert.fail(`Failed to locate card named ${name} in current list`); - });*/ - } - - async verifyBucktNotInListByName(name){ - await this.assertNotPresent(await bucketsTab.getBucketCardSelectorByName(name)); - } - - async verifyBucketHasRetentionPolicy(name, rp){ - - await this.driver.sleep(500); //todo - this is troubleshoot of occasional old value for rpText - - await this.bucketsTab.getBucketCardRetentionByName(name).then(async elem => { - await elem.getText().then(async rpText => { - if(rp.toLowerCase() === 'never'){ - let rpPolicy = rpText.trim().toLowerCase().split(' '); - rpPolicy.shift(); - await expect(rpPolicy[0]).to.equal('forever'); - }else{ - await expect(rpText).to.include(durationsMap.get(rp)); - //let policy = rp.trim().toLowerCase().split(' '); - // let rpPolicy = rpText.trim().toLowerCase().split(':'); - // rpPolicy.shift(); //remover first 'Retenition: string' - // await expect(rpPolicy[0]) - // for( let i = 0; i < policy.length; i += 2) { - // await expect(parseInt(policy[i])).to.equal(parseInt(rpPolicy[i])); - // await expect(policy[i+1]).to.equal(rpPolicy[i+1]); - // } - } - - }); - }); - - /* - await this.bucketsTab.getBucketCards().then(async cards => { - for(let i = 0; i < cards.length; i++){ - let crd_nm = await cards[i].findElement(By.xpath('.//span[contains(@class,\'cf-resource-name--text\')]/span')); - if((await crd_nm.getText()) === name){ - await cards[i].findElement(By.xpath('.//*[@data-testid=\'cf-resource-card--meta-item\']')).then(async elem => { - //await console.log("DEBUG cards[i] " + await elem.getText()); - // rpText should be of form e.g. 'Retention: 28 days' - await elem.getText().then(async rpText => { - console.log("DEBUG rp #" + rp + "#"); - console.log("DEBUG rpText #" + rpText + "#"); - let policy = rp.trim().toLowerCase().split(' '); - let rpPolicy = rpText.trim().toLowerCase().split(' '); - rpPolicy.shift(); //remover first 'Retenition: string' - for( let i = 0; i < policy.length; i += 2) { - await expect(parseInt(policy[i])).to.equal(parseInt(rpPolicy[i])); - await expect(policy[i+1]).to.equal(rpPolicy[i+1]); - } - }) - }); - return; - } - } - assert.fail(`Failed to locate card named ${name} in current list`); - - })*/ - } - - async clickOnBucketNamed(name){ - await this.clickAndWait(await this.bucketsTab.getBucketCardName(name), - //N.B. popup sometimes slow to load - async () => { await this.driver.sleep(1000);}); // todo better wait - } - - async clickOnBucketSettings(name){ - await this.clickAndWait(await this.bucketsTab.getBucketCardSettingsByName(name)); - } - - async clickSaveChanges(){ - await this.bucketsTab.getPopupSaveChanges().then(async btn => { - await btn.click(); - }); - } - - async setFilterValue(text){ - let cardCt = (await this.bucketsTab.getBucketCards()).length; - console.log(`DEBUG cardCt ${cardCt}`); - await this.bucketsTab.getFilterInput().then( async input => { - await input.clear().then(async () => { - await input.sendKeys(text).then( async () => { - - await this.driver.sleep(500); //wait below seems to be blocking - - /*await this.driver.wait(async () => { - return (await this.bucketsTab.getBucketCards()).length < cardCt; - }); */ - }); - }); - }); - } - - async clearFilterValue(){ - //let cardCt = (await this.bucketsTab.getBucketCards()).length; - await this.bucketsTab.getFilterInput().then(async input => { - await input.clear().then(async() => { - await this.driver.sleep(500); //wait commented below seems to hang - /*await this.driver.wait(async () => { - return (await this.bucketsTab.getBucketCards()).length > cardCt; - }); */ - }); - }); - } - - async ensureNameSortOrder(order){ - await this.bucketsTab.getNameSorter().then(async elem => { - if(!(await elem.getAttribute('title')).toLowerCase().includes(order.toLowerCase())){ - await elem.click().then(async () => { - await this.driver.wait(until.elementLocated(By.css((await bucketsTab.getNameSorterSelector()).selector))); - }); - } - }); - } - - async clickRetentionSort(){ - await this.clickAndWait(await this.bucketsTab.getPolicySorter()); - } - - async clickBucketsFilter(){ - await this.clickAndWait(await this.bucketsTab.getFilterInput()); - } - - async hoverOverCardNamed(name){ - await this.hoverOver(await this.bucketsTab.getBucketCardByName(name)); - } - - async verifyBucketCardDeleteNotPresent(name){ - //await this.driver.executeScript('arguments[0].blur()', await this.bucketsTab.getBucketCardDeleteByName(name)); - //await this.bucketsTab.getBucketCardByName('_tasks').then(async elem => { - // await elem.click().then(async () => { //remove focus from list - // await this.driver.sleep(500); //fix later - losing patience - await this.assertNotVisible(await this.bucketsTab.getBucketCardDeleteByName(name)); - // }); - //}); - } - - async verifyBucketCardPopoverVisible(name, toBeVisible){ - if(toBeVisible){ - await this.assertVisible(await this.bucketsTab.getBucketCardPopover()); - }else{ - await this.assertNotVisible(await this.bucketsTab.getBucketCardPopover()); - } - } - - async verifyBucketCardPopover(present){ - if(present){ - await this.assertPresent(await bucketsTab.getPopoverSelector()); - }else{ - await this.assertNotPresent(await bucketsTab.getPopoverSelector()); - } - } - - async clickBucketCardDelete(name){ - await this.clickAndWait(await this.bucketsTab.getBucketCardDeleteByName(name)); //todo better wait - /*await this.bucketsTab.getBucketCardDeleteByName(name).then(async elem => { - await elem.click().then(async () => { - await this.driver.wait(until.elementIsVisible( - await this.bucketsTab.getBucketCardDeleteConfirmByName(name))); - }); - });*/ - } - - async clickBucketCardDeleteConfirm(name){ - await this.bucketsTab.getBucketCardDeleteConfirmByName(name).then(async elem => { - await elem.click().then(async () => { - - await this.driver.sleep(500); // todo - find better wait - however below is flakey - - // await this.driver.wait(until.stalenessOf(await this.bucketsTab.getBucketCardDeleteByName(name))); - }); - }); - } - - async clickAddDataButtonOfCard(name){ - await this.bucketsTab.getBucketCardAddDataByName(name).then(async elem => { - await elem.click().then(async () => { - await this.driver.wait(until.elementIsVisible(await this.bucketsTab.getBucketCardPopover())); - }); - }); - } - - async clickPopoverItemForBucketCard(name, item){ - await this.bucketsTab.getBucketCardPopoverItemByName(name, item).then(async elem => { - await elem.click().then( async () => { - if(item.toLowerCase().includes('scrape metrics')) { - await this.driver.wait(until.elementIsVisible(await this.bucketsTab.getPopupOverlayContainer())); - }else{ //line protocol and telegraf lead to wizard - await this.driver.wait(until.elementIsVisible(await this.bucketsTab.getWizardStepTitle())) - .catch(async err => { - console.log('Caught err' + err); - throw err; - }); - } - }); - }); - } - - async clickPopoverItem(item){ - await this.clickAndWait(await this.bucketsTab.getPopoverItem(item)); - } - - async verifyLineProtocolWizardVisible(visibility){ - if(visibility){ - await this.assertVisible(await this.bucketsTab.getWizardStepTitle()); - //await this.assertVisible(await this.bucketsTab.getWizardStepSubTitle()); - await this.assertVisible(await this.bucketsTab.getWizardDragAndDrop()); - await this.assertVisible(await this.bucketsTab.getWizardRadioUploadFile()); - await this.assertVisible(await this.bucketsTab.getWizardRadioManual()); - await this.assertVisible(await this.bucketsTab.getWizardPrecisionDropdown()); - // 13.8 following is no longer part of the popup - made dynamic based on content - //await this.assertVisible(await this.bucketsTab.getWizardContinueButton()); - }else{ - await this.assertNotPresent(await bucketsTab.getWizardStepTitleSelector()); - await this.assertNotPresent(await bucketsTab.getWizardStepSubTitleSelector()); - await this.assertNotPresent(await bucketsTab.getWizardContinueButtonSelector()); - } - } - - async verifyDataPointsTextAreaVisible(visibility){ - if(visibility){ - await this.assertVisible(await this.bucketsTab.getWizardTextArea()); - }else{ - await this.assertNotVisible(await this.bucketsTab.getWizardTextArea()); - } - } - - async clickRadioButton(name){ - if(name.toLowerCase().includes('manual')) { - await this.bucketsTab.getWizardRadioManual().then(async elem => { - await elem.click().then( async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - }else{ - await this.bucketsTab.getWizardRadioUploadFile().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - } - - async enterLineProtocolDataPoints(count, value, start, mode){ - let samples = []; - let dataPoints = []; - let nowMillis = new Date().getTime(); - //line protocol i.e. myMeasurement,host=myHost testField="testData" 1556896326 - let intervals = await influxUtils.getIntervalMillis(count, start); - let startMillis = nowMillis - intervals.full; - switch(mode.toLowerCase()){ - case 'fibonacci': - samples = await influxUtils.genFibonacciValues(count); - break; - default: - throw `Unhandled mode ${mode}`; - } - for(let i = 0; i < samples.length; i++){ - console.log(`${mode},test=bucketSteps ${value}=${samples[i]} ${startMillis + (intervals.step * i)}\n`); - dataPoints.push(`${mode},test=bucketSteps ${value}=${samples[i]} ${startMillis + (intervals.step * i)}\n`); - } - await this.bucketsTab.getWizardTextArea().then(async elem => { - dataPoints.forEach(async point => { - await elem.sendKeys(point); - }); - }); - - } - - async enterLineProtocolRawData(data){ - await this.bucketsTab.getWizardTextArea().then(async elem => { - await elem.sendKeys(data).then(async () => { - await this.driver.sleep(500); // todo better wait - }); - }); - } - - async clickLineProtocolPrecisionDropdown(){ - await this.bucketsTab.getWizardPrecisionDropdown().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - - async clickLineProtocolContinue(){ - await this.bucketsTab.getWizardContinueButton().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - - async clickLineProtocolWrite(){ - await this.clickAndWait(await this.bucketsTab.getWizardWriteDataButton()) - } - - async clickLineProtocolPrecisionItem(prec){ - await this.bucketsTab.getWizardDropdownPrecisionItem(prec).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - - async verifyLineProtocolWizardSecondStep(){ - await this.assertVisible(await this.bucketsTab.getWizardSparkleSpinner()); - await this.assertVisible(await this.bucketsTab.getWizardStepStateText()); - //await this.assertVisible(await this.bucketsTab.getWizardCloseButton()); - - } - - async verifyWizardStepStatusMessage(msg){ - await this.bucketsTab.getWizardStepStateText().then(async elem => { - await elem.getText().then(async elText => { - expect(elText).to.equal(msg); - }); - if(msg.toLowerCase().includes('success')) { - await elem.getCssValue('color').then(async color => { - expect(color).to.equal('rgba(190, 194, 204, 1)'); - }); - } - }); - } - - async verifyWizardStepStatusMessageContains(msg){ - await this.bucketsTab.getWizardStepStateText().then(async elem => { - await elem.getText().then(async elText => { - expect(elText).to.include(msg); - }); - if(msg.toLowerCase().includes('success')) { - await elem.getCssValue('color').then(async color => { - expect(color).to.equal('rgba(78, 216, 160, 1)'); - }); - }/*else{ //no longer colored -- 13.8.20 - await elem.getCssValue('color').then(async color => { - expect(color).to.equal('rgba(255, 133, 100, 1)'); - }); - }*/ - }); - - } - - async clickLineProtocolFinish(){ - await this.bucketsTab.getWizardFinishButton().then( async button => { - await button.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - - async clickLineProtocolClose(){ - await this.clickAndWait(await this.bucketsTab.getWizardCloseButton()); - } - - async clickLineProtocolCancel(){ - await this.clickAndWait(await this.bucketsTab.getWizardCancelButton()); - } - - async clickLineProtocolCancelIcon(){ - await this.clickAndWait(await this.bucketsTab.getWizardDismissButton()); - } - - async clickDataWizardPreviousButton(){ - await this.clickAndWait(await this.bucketsTab.getDataWizardPreviousButton()); - } - - -} - -module.exports = bucketsSteps; - diff --git a/e2e/src/steps/loadData/clientLibsSteps.js b/e2e/src/steps/loadData/clientLibsSteps.js deleted file mode 100644 index 675546d005..0000000000 --- a/e2e/src/steps/loadData/clientLibsSteps.js +++ /dev/null @@ -1,84 +0,0 @@ -const { By } = require('selenium-webdriver'); -const { expect } = require('chai'); -var ncp = require('copy-paste'); - -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const clientLibsTab = require(__srcdir + '/pages/loadData/clientLibsTab.js'); - -class clientLibsSteps extends baseSteps { - - constructor(driver) { - super(driver); - this.clibTab = new clientLibsTab(driver); - } - - async isLoaded() { - await this.clibTab.isTabLoaded(); - } - - async verifyClientLibsTabIsLoaded(){ - await this.clibTab.isTabLoaded(); - await this.assertVisible(await this.clibTab.getClientURL()); - await this.assertVisible(await this.clibTab.getLibTileByName('csharp')); - await this.assertVisible(await this.clibTab.getLibTileByName('java')); - await this.assertVisible(await this.clibTab.getLibTileByName('python')); - } - - async clickLibTileByName(name){ - await this.clickAndWait(await this.clibTab.getLibTileByName(name)); - } - - async verifyCSharpPopupLoaded(){ - //await this.clickAndWait(await this.clibTab.getCopy2ClipByLabel('Package Manager')); - await this.assertVisible(await this.clibTab.getPopupDismiss()); - await this.assertVisible(await this.clibTab.getPopupBody()); - await this.verifyElementContainsText(await this.clibTab.getPopupTitle(), 'C# Client Library'); - } - - async verifyGoPopupLoaded(){ - await this.assertVisible(await this.clibTab.getPopupDismiss()); - await this.assertVisible(await this.clibTab.getPopupBody()); - await this.verifyElementContainsText(await this.clibTab.getPopupTitle(), 'GO Client Library'); - } - - async verifyJavaPopupLoaded(){ - await this.assertVisible(await this.clibTab.getPopupDismiss()); - await this.assertVisible(await this.clibTab.getPopupBody()); - await this.verifyElementContainsText(await this.clibTab.getPopupTitle(), 'Java Client Library'); - } - - async verifyNodePopupLoaded(){ - await this.assertVisible(await this.clibTab.getPopupDismiss()); - await this.assertVisible(await this.clibTab.getPopupBody()); - await this.verifyElementContainsText(await this.clibTab.getPopupTitle(), 'JavaScript/Node.js Client Library'); - } - - async verifyPythonPopupLoaded(){ - await this.assertVisible(await this.clibTab.getPopupDismiss()); - await this.assertVisible(await this.clibTab.getPopupBody()); - await this.verifyElementContainsText(await this.clibTab.getPopupTitle(), 'Python Client Library'); - } - - async clickCopyToClipboardText(label){ - await this.clickAndWait(await this.driver.findElement(By.xpath(`//p[text() = '${label}']/following-sibling::div[1]//button`)));//can be slow to perform copy - } - - async verifyClipboardTextFrom(label){ - let text = await (await this.driver.findElement(By.xpath(`//p[text() = '${label}']/following-sibling::div[1]//code`))).getText(); - console.log('DEBUG text ' + text); - let clipboard = ncp.paste(); - console.log ('DEBUG clipboard ' + clipboard); - } - - async verifyPopupGithubLink(token){ - - await this.clibTab.getPopupGithubLink().then(async link => { - await link.getAttribute('href').then( async href => { - expect(href).to.include(token); - }); - }); - - } -} - -module.exports = clientLibsSteps; diff --git a/e2e/src/steps/loadData/loadDataSteps.js b/e2e/src/steps/loadData/loadDataSteps.js deleted file mode 100644 index 2366814472..0000000000 --- a/e2e/src/steps/loadData/loadDataSteps.js +++ /dev/null @@ -1,200 +0,0 @@ -const expect = require('chai').expect; -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const loadDataPage = require(__srcdir + '/pages/loadData/loadDataPage.js'); - -const { Key } = require('selenium-webdriver'); - - -class loadDataSteps extends influxSteps{ - - constructor(driver){ - super(driver); - this.ldPage = new loadDataPage(__wdriver); - } - - async isLoaded(){ - await this.ldPage.isLoaded(); - } - - async verifyIsLoaded(){ - this.assertVisible(await this.ldPage.getTabByName('Buckets')); - this.assertVisible(await this.ldPage.getTabByName('Telegraf')); - this.assertVisible(await this.ldPage.getTabByName('Scrapers')); - } - - async clickTab(name){ - await this.ldPage.getTabByName(name).then(async tab => { - await tab.click(); - }); - } - - async createScraperPopupLoaded(){ - await this.assertVisible(await this.ldPage.getCreateScraperTitle()); - await this.assertVisible(await this.ldPage.getCreateScraperDismiss()); - await this.assertVisible(await this.ldPage.getCreateScraperNameInput()); - await this.assertVisible(await this.ldPage.getCreateScraperBucketDropdown()); - await this.assertVisible(await this.ldPage.getCreateScraperUrlInput()); - await this.assertVisible(await this.ldPage.getCreateScraperCancel()); - await this.assertVisible(await this.ldPage.getCreateScraperSubmit()); - } - - async dismissCreateScraperPopup(){ - await this.ldPage.getCreateScraperDismiss().then(async btn => { - btn.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - - async verifyCreateScraperPopupNotPresent(){ - await this.assertNotPresent(loadDataPage.getCreateScraperTitleSelector()); - await this.assertNotPresent(loadDataPage.getCreateScraperNameInputSelector()); - await this.assertNotPresent(loadDataPage.getCreateScraperUrlInputSelector()); - } - - async cancelCreateScraperPopup(){ - await this.ldPage.getCreateScraperCancel().then(async btn => { - await btn.click().then(async () => { - await this.driver.sleep(500); //todo better wait - }); - }); - } - - async clearCreateScraperNameInput(){ - await this.ldPage.getCreateScraperNameInput().then(async input => { - await input.sendKeys(Key.END); - while((await input.getAttribute('value')).length > 0){ - await input.sendKeys(Key.BACK_SPACE); - } - await this.driver.sleep(200); - //N.B. clear skips hook that triggers messages and other state changes - //await input.clear().then( async () => { - // await this.driver.sleep(500); // todo better wait - //}) - }); - } - - async clearCreateScraperUrlInput(){ - await this.ldPage.getCreateScraperUrlInput().then(async input => { - await input.sendKeys(Key.END); - while((await input.getAttribute('value')).length > 0){ - await input.sendKeys(Key.BACK_SPACE); - } - await this.driver.sleep(200); - }); - } - - async verifyCreateScraperSubmitEnabled(state = true){ - await this.ldPage.getCreateScraperSubmit().then(async elem => { - expect(await elem.isEnabled()).to.equal(state); - }); - } - - async enterCreateScraperName(name){ - await this.ldPage.getCreateScraperNameInput().then(async elem => { - await this.clearInputText(elem).then(async () => { - //await elem.clear().then(async () => { - await elem.sendKeys(name).then(async () => { - await this.driver.sleep(200); // todo better wait - }); - }); - }); - } - - async enterCreateScraperTargetURL(url){ - await this.ldPage.getCreateScraperUrlInput().then(async elem => { - await elem.sendKeys(url).then(async () => { - await this.driver.sleep(200); // todo better wait - }); - }); - } - - async clickCreateScraperBucketsDropdown(){ - await this.ldPage.getCreateScraperBucketDropdown().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async selectCreateScraperBucketsItem(item){ - await this.ldPage.getCreateScraperBucketDropdownItem(item).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); //todo better wait - }); - }); - } - - async verifyCreateScraperBucketsDropdownItem(item){ - await this.ldPage.getCreateScraperBucketDropdownItem(item).then(async elem => { - await expect(await elem.isDisplayed()).to.equal(true); - }); - } - - async verifyNoBucketItemsInBucketsDropdownShown(){ - await this.assertNotPresent(loadDataPage.getCreateScraperBucketDropdownItemsSelector()); - } - - async clickCreateScraperBucketCreateButton(){ - await this.ldPage.getCreateScraperSubmit().then(async btn => { - await btn.click().then(async () => { - await this.driver.sleep(300); // todo better wait - }); - }); - } - - async verifyCreateTelegrafWizardLoaded(){ - await this.assertVisible(await this.ldPage.getPopupWizardTitle()); - await this.assertVisible(await this.ldPage.getPopupWizardSubTitle()); - await this.assertVisible(await this.ldPage.getPopupWizardContinue()); - await this.assertVisible(await this.ldPage.getBucketDropdown()); - await this.assertVisible(await this.ldPage.getPluginsFilter()); - } - - async clickBucketsDropdown(){ - await this.ldPage.getBucketDropdown().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async selectBucketsDropdownItem(item){ - await this.ldPage.getBucketDropdownItem(item).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async selectTelegrafWizardPluginTile(tile){ - await this.ldPage.getPluginTileByName(tile).then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); //todo better wait - }); - }); - } - - async enterTelegrafWizardName(name){ - await this.ldPage.getTelegrafNameInput().then(async elem => { - await this.clearInputText(elem).then(async () => { - await elem.sendKeys(name).then(async () => { - await this.driver.sleep(100); //todo better wait - }); - }); - }); - } - - async enterTelegrafWizardDescr(descr){ - await this.ldPage.getTelegrafDescrInput().then(async elem => { - await elem.clear().then(async () => { - await elem.sendKeys(descr).then(async () => { - await this.driver.sleep(100); //todo better wait - }); - }); - }); - } - -} - -module.exports = loadDataSteps; diff --git a/e2e/src/steps/loadData/scrapersSteps.js b/e2e/src/steps/loadData/scrapersSteps.js deleted file mode 100644 index 579eb8e45e..0000000000 --- a/e2e/src/steps/loadData/scrapersSteps.js +++ /dev/null @@ -1,211 +0,0 @@ -const { By, Key } = require('selenium-webdriver'); -const { expect } = require('chai'); - -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const scrapersTab = require(__srcdir + '/pages/loadData/scrapersTab.js'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -let namedQueriesMap = new Map(); -namedQueriesMap.set('Measurements', 'from(bucket: "[BUCKET]")\n' + - ' |> range(start: -1h, stop: now())\n' + - ' |> filter(fn: (r) => true)\n' + - ' |> keep(columns: ["_measurement"])\n' + - ' |> group()\n' + - ' |> distinct(column: "_measurement")\n' + - ' |> limit(n: 200)\n' + - ' |> sort()'); - -class scrapersSteps extends baseSteps{ - - constructor(driver){ - super(driver); - this.scrapeTab = new scrapersTab(driver); - } - - async isLoaded(){ - await this.scrapeTab.isTabLoaded(); - } - - async verifyExistsCardByName(card){ - await this.assertVisible(await this.scrapeTab.getScraperCardByName(card)); - } - - async verifyScraperCardHasBucket(scraper, bucketName){ - await this.driver.findElement( - By.xpath(`//*[@data-testid='resource-card'][.//span[text()='${scraper}']]//*[@data-testid='resource-list--meta']//*[contains(text(),'Bucket')]`)) - .then(async elem => { - await elem.getText().then(async elText => { - await expect(elText).to.include(bucketName); - }); - }); - } - - async verifyScraperCardHasEndpoint(scraper, endpoint){ - await this.driver.findElement( - By.xpath(`//*[@data-testid='resource-card'][.//span[text()='${scraper}']]//*[@data-testid='resource-list--meta']//*[contains(text(),'URL')]`)) - .then(async elem => { - await elem.getText().then(async elText => { - await expect(elText).to.include(endpoint); - }); - }); - } - - async verifyScrapersTabIsLoaded(){ - await this.scrapeTab.isTabLoaded(); - await this.assertVisible(await this.scrapeTab.getCreateScraperHeader()); - await this.assertVisible(await this.scrapeTab.getScrapersFilter()); - await this.assertVisible(await this.scrapeTab.getSortTypeButton()); - //await this.assertVisible(await this.scrapeTab.getNameSort()); - //await this.assertVisible(await this.scrapeTab.getUrlSort()); - //await this.assertVisible(await this.scrapeTab.getBucketSort()); - } - - async clickCreateScraperButtonEmpty(){ - await this.scrapeTab.getCreateScraperEmpty().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); //todo implement better wait; - }); - }); - } - - async clickCreateScraperButtonInHeader(){ - await this.scrapeTab.getCreateScraperHeader().then(async elem => { - await elem.click().then(async () => { - await this.driver.sleep(100); //todo implement better wait; - }); - }); - } - - async verifyCreateScraperEmptyNotPresent(){ - await this.assertNotPresent(scrapersTab.getCreateScraperEmptySelector()); - } - - async verifyScrapersSortOrderByName(items){ - let itemsArray = items.split(','); - await this.scrapeTab.getScraperCards().then(async cards => { - for( let i = 0; i < cards.length; i++){ - let cardName = await cards[i].findElement(By.xpath('.//span[contains(@class,\'cf-resource-name--text\')]/span')); - let cardText = await cardName.getText(); - expect(cardText).to.equal(itemsArray[i]); - } - }); - } - - async enterScrapersFilterValue(value){ - await this.scrapeTab.getScrapersFilter().then(async filter => { - await filter.clear().then(async () => { - await filter.sendKeys(value).then(async () => { - await this.driver.sleep(100); //todo implement better wait - }); - }); - }); - } - - async clearScraperFilter(){ - await this.scrapeTab.getScrapersFilter().then(async filter => { - await filter.clear().then(async () => { - await this.driver.sleep(100); //todo implement better wait - }); - }); - } - - async verifyScraperCardNotPresent(scraper){ - await this.assertNotPresent({type: 'xpath', selector: `//*[@data-testid='resource-card']//span[text()='${scraper}']`}); - } - - async clickScraperNameSortButton(){ - await this.scrapeTab.getNameSort().then(async button => { - await button.click().then(async () => { - await this.driver.sleep(100); //todo implement better wait - }); - }); - } - - async clickScraperURLSortButton(){ - await this.scrapeTab.getUrlSort().then(async button => { - await button.click().then(async () => { - await this.driver.sleep(100); //todo implement better wait - }); - }); - } - - async clickScraperBucketSortButton(){ - await this.scrapeTab.getBucketSort().then(async button => { - await button.click().then(async() => { - await this.driver.sleep(100); - }); - }); - } - - async mouseOverScraperCardName(name){ - await this.hoverOver(await this.scrapeTab.getScraperCardName(name)); - } - - async clickScraperCardNameEditButton(name){ - await this.scrapeTab.getScraperCardNameEditButton(name).then(async button => { - await button.click().then(async () => { - await this.driver.sleep(100); // todo implement better wait - }); - }); - } - - async enterNewScraperName(newName, oldName){ - await this.scrapeTab.getScraperCardNameEditField(oldName).then(async input => { - await input.sendKeys(newName + Key.ENTER).then(async () => { - await this.driver.sleep(100); //todo implement better wait - }); - }); - } - - async verifyNamedQueryResponseValues(queryName, userName, bucketName, values, field = '_value'){ - let user = await influxUtils.getUser(userName); - let query; - query = namedQueriesMap.get(queryName); - query = query.replace('[BUCKET]', (bucketName === 'DEFAULT') ? user.bucket : bucketName); - - let results = await influxUtils.query(user.username, query); - - let targetValues = values.split(','); - - targetValues.forEach(async value => { - await expect(results.filter(rec => - rec[field] === targetValues[0] - ).length).to.be.above(0, `failed to locate record with value ${value} in field ${field}`); - }); - } - - async verifyScraperCardDeleteNotPresent(name){ - await this.scrapeTab.getScrapersFilter().then(async elem => { - await elem.click().then(async () => { //remove focus from list - await this.driver.sleep(500); //todo fix later - losing patience - better wait - await this.assertNotVisible(await this.scrapeTab.getScraperCardDeleteByName(name)); - }); - }); - - } - - async hoverOverScraperCard(name){ - await this.hoverOver(await this.scrapeTab.getScraperCardByName(name)); - } - - async clickScraperCardDeleteButton(name){ - await this.scrapeTab.getScraperCardDeleteByName(name).then(async button => { - await button.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async clickScraperCardDeleteConfirm(name){ - await this.scrapeTab.getScraperCardDeleteConfirmByName(name).then(async button => { - await button.click().then(async () => { - await this.driver.sleep(200); //todo better wait - }); - }); - } - - - -} - -module.exports = scrapersSteps; diff --git a/e2e/src/steps/loadData/telegrafsSteps.js b/e2e/src/steps/loadData/telegrafsSteps.js deleted file mode 100644 index 0edbab1957..0000000000 --- a/e2e/src/steps/loadData/telegrafsSteps.js +++ /dev/null @@ -1,500 +0,0 @@ -const { expect } = require('chai'); -const { By, Key } = require('selenium-webdriver'); - -const loadDataSteps = require(__srcdir + '/steps/loadData/loadDataSteps.js'); -const telegrafsTab = require(__srcdir + '/pages/loadData/telegrafsTab.js'); -const basePage = require(__srcdir + '/pages/basePage.js'); - -class telegrafsSteps extends loadDataSteps{ - - constructor(driver){ - super(driver); - this.teleTab = new telegrafsTab(driver); - } - - async isLoaded(){ - await this.teleTab.isTabLoaded(); - } - - async verifyTelegrafCardByName(name){ - await this.assertVisible(await this.teleTab.getTelegraphCardByName(name)); - } - - async verifyTelegrafTabLoaded(){ - await this.teleTab.isTabLoaded(); - } - - async clickCreateTelegrafButtonEmpty(){ - await this.teleTab.getCreateConfigInBody().then(async button => { - await button.click().then(async () => { - await this.driver.sleep(100); // todo better wait - }); - }); - } - - async clickTelegrafCard(name){ - await this.clickAndWait(await this.teleTab.getTelegrafCardByName(name)); - } - - async clickCreateTelegrafButtonInHeader(){ - await this.clickAndWait(await this.teleTab.getCreateConfigInHeader(), - //sometimes default wait overruns full load - async() => { this.driver.sleep(1000);}); // todo pass in better wait - } - - async verifyWizardLoadedP1(){ - await this.assertVisible(await this.teleTab.getPopupDismiss()); - await this.assertVisible(await this.teleTab.getPopupWizardTitle()); - await this.assertVisible(await this.teleTab.getPopupWizardSubTitle()); - await this.assertVisible(await this.teleTab.getPopupWizardContinue()); - await this.assertVisible(await this.teleTab.getBucketDropdownBtn()); - await this.assertVisible(await this.teleTab.getPluginFilter()); - await this.assertVisible(await this.teleTab.getPluginTileByName('System')); - } - - async verifyCreateTelegrafWizardNotPresent(){ - await this.assertNotPresent(basePage.getPopupWizardTitleSelector()); - await this.assertNotPresent(basePage.getPopupWizardSubTitleSelector()); - await this.assertNotPresent(telegrafsTab.getPluginTitleSelectorByName('System')); - } - - async clickCreateConfigBucketDropdown(){ - await this.clickAndWait(await this.teleTab.getBucketDropdownBtn(), - //some kind of slow animation? - async () => {await this.driver.sleep(2000);}); // todo pass in better wait method - } - - async clickCreateConfigBucketDropdownItem(item){ - await this.clickAndWait(await this.teleTab.getBucketDropdownItem(item)); - } - - async clickCreateConfigPluginTile(plugin){ - await this.clickAndWait(await this.teleTab.getPluginTileByName(plugin)); - } - - async enterValueIntoPluginsFilter(value){ - await this.teleTab.getPluginsFilter().then(async filter => { - await filter.sendKeys(value).then(async () => { - this.driver.sleep(100); // todo better wait - }); - }); - } - - async clearWizardPluginFilter(){ - await this.clearInputText(await this.teleTab.getPluginsFilter()); - } - - async verifyCreateWizardPluginTileVisible(plugin){ - await this.assertVisible(await this.teleTab.getPluginTileByName(plugin)); - } - - async verifyCreateWizardPluginTileNotPresent(plugin){ - await this.assertNotPresent(await telegrafsTab.getPluginTitleSelectorByName(plugin)); - } - - async verifyCreateWizardPluginTileSelected(plugin){ - await this.teleTab.getPluginTileByName(plugin).then(async elem => { - await elem.getAttribute('class').then(async elClass => { - await expect(elClass).to.include('selected'); - }); - }); - } - - async verifyCreateWizardPluginTileNotSelected(plugin){ - await this.teleTab.getPluginTileByName(plugin).then(async elem => { - await elem.getAttribute('class').then(async elClass => { - await expect(elClass).to.not.include('selected'); - }); - }); - } - - async verifyCreateWizardStep2Loaded(){ - await this.verifyElementText(await this.teleTab.getPopupWizardTitle(), 'Configure Plugins'); - await this.verifyElementContainsText(await this.teleTab.getPopupWizardSubTitle(), 'Configure each plugin'); - await this.assertVisible(await this.teleTab.getPopupWizardBack()); - await this.assertVisible(await this.teleTab.getConfigurationPluginsSideBar()); - await this.assertVisible(await this.teleTab.getPopupWizardBack()); - } - - async verifyCreateWizardStep3Loaded(){ - await this.verifyElementText(await this.teleTab.getPopupWizardTitle(), 'Test your Configuration'); - await this.verifyElementContainsText(await this.teleTab.getPopupWizardSubTitle(), 'Start Telegraf and ensure data is being written to InfluxDB'); - await this.assertVisible(await this.teleTab.getPopupWizardBack()); - await this.assertVisible(await this.teleTab.getPopupWizardBack()); - await this.assertVisible(await this.teleTab.getCodeToken()); - await this.assertVisible(await this.teleTab.getCodeCliTelegraf()); - await this.assertVisible(await this.teleTab.getCopyToClipboardToken()); - await this.assertVisible(await this.teleTab.getCopyToClipboardCommand()); - await this.verifyElementContainsText(await this.teleTab.getCodeToken(), 'INFLUX_TOKEN'); - await this.verifyElementContainsText(await this.teleTab.getCodeCliTelegraf(), `telegraf --config ${__config.influx_url}/api/v2/telegrafs/`); - } - - async verifyCreateWizardStep2PluginsList(plugins){ - let pList = plugins.split(','); - for(let i = 0; i < pList.length; i++){ - await expect(await this.teleTab.getPluginItemByName(pList[i])).to.not.be.undefined; - } - } - - async verifyCreateWizardPluginState(plugin, state){ - await this.teleTab.getPluginItemByName(plugin).then(async elem => { - switch(state.toLowerCase()){ - case 'success': - expect(await elem.getAttribute('class')).to.include('success'); - break; - case 'failure': - case 'fail': - case 'error': - expect(await elem.getAttribute('class')).to.include('error'); - break; - default: - expect(await elem.getAttribute('class')).to.equal('side-bar--tab'); - break; - } - }); - } - - async clickCreateWizardPluginItem(plugin){ - await this.clickAndWait(await this.teleTab.getPluginItemByName(plugin)); // todo better wait - } - - async verifyEditPluginStepLoaded(plugin){ - - await this.assertVisible(await this.teleTab.getPopupDismiss()); - await this.assertVisible(await this.teleTab.getPopupWizardContinue()); - - switch(plugin.toLowerCase()){ - case 'docker': - await this.assertVisible(await this.teleTab.getPluginDockerEditEndpoint()); - await this.verifyElementText(await this.teleTab.getPopupWizardTitle(), 'Docker'); - await this.verifyWizardDocsLinkURL('https://github.com/influxdata/telegraf/tree/master/plugins/inputs/docker'); - // todo verify subtitle link to documentation - break; - case 'kubernetes': - await this.assertVisible(await this.teleTab.getPluginK8SEditEndpoint()); - await this.verifyElementText(await this.teleTab.getPopupWizardTitle(), 'Kubernetes'); - await this.verifyWizardDocsLinkURL('https://github.com/influxdata/telegraf/tree/master/plugins/inputs/kubernetes'); - break; - case 'nginx': - await this.assertVisible(await this.teleTab.getPluginNGINXEditEndpoint()); - await this.verifyElementText(await this.teleTab.getPopupWizardTitle(), 'Nginx'); - await this.verifyWizardDocsLinkURL('https://github.com/influxdata/telegraf/tree/master/plugins/inputs/nginx'); - break; - case 'redis': - await this.assertVisible(await this.teleTab.getPluginRedisServersEditEndpoint()); - await this.assertVisible(await this.teleTab.getPluginRedisPasswordEditEndpoint()); - await this.verifyElementText(await this.teleTab.getPopupWizardTitle(), 'Redis'); - await this.verifyWizardDocsLinkURL('https://github.com/influxdata/telegraf/tree/master/plugins/inputs/redis'); - break; - default: - throw `unsupported plugin ${plugin}`; - } - } - - async enterValuesIntoFields(values, fields){ - let fieldsArr = fields.split(','); - let valuesArr = values.split(','); - for(let i = 0; i < fieldsArr.length && i < valuesArr.length; i++){ - if(valuesArr[i].toLowerCase() === 'skip'){ - continue; - } - switch(fieldsArr[i].toLowerCase()){ - case 'endpoint': - await this.teleTab.getPluginDockerEditEndpoint().then(async elem => { - await elem.sendKeys(valuesArr[i]); - }); - break; - case 'url': - await this.teleTab.getPluginK8SEditEndpoint().then(async elem => { - await elem.sendKeys(valuesArr[i]); - }); - break; - case 'urls': - await this.teleTab.getPluginNGINXEditEndpoint().then(async elem => { - await elem.sendKeys(valuesArr[i] + Key.ENTER); - }); - break; - case 'servers': - await this.teleTab.getPluginRedisServersEditEndpoint().then(async elem => { - await elem.sendKeys(valuesArr[i] + Key.ENTER); - }); - break; - case 'password': - await this.teleTab.getPluginRedisPasswordEditEndpoint().then(async elem => { - await elem.sendKeys(valuesArr[i]); - }); - break; - default: - throw `unhandled field ${fields[i]}`; - } - await this.driver.sleep(100); - } - } - - async clickNGINXConfigAddUrlButton(){ - await this.clickAndWait(await this.teleTab.getPluginNGINXAddUrlButton()); - } - - async verifyNGINXConfUrlsListSize(ct){ - await this.teleTab.getPluginNGINXURLListItems().then(async list => { - await expect(await list.length).to.equal(parseInt(ct)); - }); - } - - async verifyNGINXConfUrlsListEmpty(){ - await this.assertNotPresent(telegrafsTab.getPluginNGINXURLListItemsSelector()); - } - - async clickNGINXConfUrlsFirstDelete(){ - //Getting stale element exception here in Circle CI... - // StaleElementReferenceError: stale element reference: element is not attached to the page document - await this.driver.sleep(1000); - await this.clickAndWait(await this.teleTab.getPluginNGINXDeleteFirstURL()); - } - - async clickNGINXConfUrlDeleteConfirm(){ - await this.clickAndWait(await this.teleTab.getPluginNGINXDeleteURLConfirmButton()); - } - - async verifyEditPluginErrorMessage(msgs) { - let msgArr = msgs.split(','); - for(let i = 0; i < msgArr.length; i++){ - switch(msgArr[i].toLowerCase()){ - case 'skip': - break; - case 'none': - await this.verifyInputErrorIcon(); - break; - default: - await this.verifyInputErrorIcon(); - await this.verifyElementErrorMessage(msgArr[i], false); - break; - } - } - } - - async clearCreateTelegrafPluginFields(fields){ - let fieldsArr = fields.split(','); - for(let i = 0; i < fieldsArr.length; i++){ - switch(fieldsArr[i].toLowerCase()){ - case 'endpoint': - await this.clearInputText(await this.teleTab.getPluginDockerEditEndpoint()); - break; - case 'url': - await this.clearInputText(await this.teleTab.getPluginK8SEditEndpoint()); - break; - case 'urls': - await this.clearInputText(await this.teleTab.getPluginNGINXEditEndpoint()); - //NGINX remove invalid URL from list - await this.clickAndWait(await this.driver.findElement(By.css('[data-testid=confirmation-button--button]'))); - await this.clickAndWait(await this.driver.findElement(By.css('[title=Confirm]'))); - break; - case 'servers': - await this.clearInputText(await this.teleTab.getPluginRedisServersEditEndpoint()); - break; - case 'password': - await this.clearInputText(await this.teleTab.getPluginRedisPasswordEditEndpoint()); - break; - default: - throw `unhandled field ${fields[i]}`; - - } - } - } - - async verifyBucketForTelegrafCard(name, bucket){ - await this.teleTab.getTelegrafCardByName(name).then(async card => { - await card.findElement(By.css('[data-testid=bucket-name]')).then(async elem => { - await elem.getText().then(async elText => { - expect(elText).to.include(bucket); - }); - }); - }); - } - - async verifyDescriptionForTelegrafCard(name, descr){ - await this.teleTab.getTelegrafCardDescr(name).then(async elem => { - await elem.getText().then(async elText => { - expect(elText).to.equal(descr); - }); - }); - - } - - async verifyTelegrafCardSortOrder(order){ - let itemsArray = order.split(','); - await this.teleTab.getTelegrafCards().then(async cards => { - for( let i = 0; i < cards.length; i++){ - let cardName = await cards[i].findElement(By.xpath('.//span[contains(@class,\'cf-resource-name--text\')]/span')); - let cardText = await cardName.getText(); - expect(cardText).to.equal(itemsArray[i]); - } - }); - } - - async clickTelegrafSortByName(){ - await this.clickAndWait(await this.teleTab.getNameSort()); //todo better wait - } - - async clickTelegrafSortByBucket(){ - await this.clickAndWait(await this.teleTab.getBucketSort()); //todo better wait - } - - async clickSetupInstructionsForCard(card){ - await this.clickAndWait(await this.teleTab.getTelegrafCardSetupInstructions(card)); //todo better wait - } - - async enterTelegrafsFilterValue(value){ - await this.typeTextAndWait(await this.teleTab.getTelegrafsFilter(), value); - } - - async clearTelegrafsFilter(){ - await this.clearInputText(await this.teleTab.getTelegrafsFilter()); - } - - async verifyTelegrafSetupPopup(){ - await this.verifyElementContainsText(await this.teleTab.getPopupTitle(), 'Telegraf Setup Instructions'); - await this.assertVisible(await this.teleTab.getCodeToken()); - await this.assertVisible(await this.teleTab.getCodeCliTelegraf()); - await this.assertVisible(await this.teleTab.getCopyToClipboardToken()); - await this.assertVisible(await this.teleTab.getCopyToClipboardCommand()); - await this.verifyElementContainsText(await this.teleTab.getCodeToken(), 'INFLUX_TOKEN'); - await this.verifyElementContainsText(await this.teleTab.getCodeCliTelegraf(), `telegraf --config ${__config.influx_url}/api/v2/telegrafs/`); - } - - async verifyTelegrafConfigPopup(name){ - await this.verifyElementContainsText(await this.teleTab.getPopupTitle(), `Telegraf Configuration - ${name}`); - await this.assertVisible(await this.teleTab.getDownloadConfigButton()); - await this.assertVisible(await this.teleTab.getMonacoEditor()); - } - - async clickTelegrafCardNamed(name){ - await this.clickAndWait(await this.teleTab.getTelegrafCardName(name)); //todo better wait - } - - async hoverOverTelegrafCardName(name){ - await this.hoverOver(await this.teleTab.getTelegrafCardName(name)); - } - - async hoverOverTelegrafCardDescription(card){ - await this.hoverOver(await this.teleTab.getTelegrafCardDescr(card)); - } - - async hoverOverTelegrafCard(name){ - await this.hoverOver(await this.teleTab.getTelegrafCardByName(name)); - } - - - async clickNameEditIconOfTelegrafCard(name){ - await this.clickAndWait(await this.teleTab.getTelegrafCardNameEditBtn(name)); - } - - async clickDescrEditIconOfTelegrafCard(card){ - await this.clickAndWait(await this.teleTab.getTelegrafCardDescrEditBtn(card)); - } - - async clearTelegrafCardNameInput(name){ - await this.clearInputText(await this.teleTab.getTelegrafCardNameInput(name)); - } - - async clearTelegrafCardDescrInput(name){ - await this.clearInputText(await this.teleTab.getTelegrafCardDescrInput(name)); - } - - async setNameInputOfTelegrafCard(oldName, newName){ - await this.teleTab.getTelegrafCardNameInput(oldName).then(async elem => { - await elem.sendKeys(newName + Key.ENTER).then(async () => { - await this.driver.sleep(500); // todo better wait - }); - }); - } - - async setDescriptionInputOfTelegrafCard(name, descr){ - await this.teleTab.getTelegrafCardDescrInput(name).then(async elem => { - await elem.sendKeys(descr + Key.ENTER).then(async () => { - await this.driver.sleep(500); // todo better wait - }); - }); - } - - async verifyTelegrafCardNotPresent(name){ - await this.assertNotPresent(telegrafsTab.getTelegrafCardSelectorByName(name)); - } - - async clickTelegrafCardDelete(name){ - await this.clickAndWait(await this.teleTab.getTelegrafCardDelete(name)); - } - - async clickTelegrafCardDeleteConfirm(name){ - await this.clickAndWait(await this.teleTab.getTelegrafCardDeleteConfirm(name), - async () => {await this.driver.sleep(1000);}); //longer wait - seems to sometimes be slow - } - - async clickTelegrafCardAddLabel(name){ - await this.clickAndWait(await this.teleTab.getTelegrafCardAddLabelBtn(name), - async () => { await this.driver.sleep(3000); }); //longer wait - troubleshoot labels - not appearing - } - - async verifyTelegrafCardLabelPopupNotPresent(name){ - await this.assertNotPresent(telegrafsTab.getTelegrafCardLabelPopupSelector(name)); - } - - async verifyTelegrafCardLabelPopupIsVisible(name){ - await this.assertVisible(await this.teleTab.getTelegrafCardLabelPopup(name)); - } - - async verifyTelegrafCardLabelPopupSelectItem(name, item){ - await this.assertVisible(await this.teleTab.getTelegrafCardLabelPopupListItem(name, item)); - } - - async verifyTelegrafCardLabelPopupSelectItemNotPresent(name, item){ - await this.assertNotPresent(telegrafsTab.getTelegrafCardLabelPopupListItemSelector(name, item)); - } - - async filterTelegrafCardLabeList(name, term){ - await this.teleTab.getTelegrafCardLabelPopupFilter(name).then(async filter => { - await filter.sendKeys(term).then(async () => { - await this.driver.sleep(150); //todo better wait - }); - }); - } - - async enterTermIntoTelegrafCardLabelFilter(name, term){ - await this.teleTab.getTelegrafCardLabelPopupFilter(name).then(async filter => { - await filter.sendKeys(term + Key.ENTER).then(async () => { - await this.driver.sleep(150); //todo better wait - }); - }); - } - - async clearTelegrafCardLabelFilter(name){ - await this.clearInputText(await this.teleTab.getTelegrafCardLabelPopupFilter(name)); - } - - async clickTelegrafCardLabelPopupSelectItem(name, item){ - await this.clickAndWait(await this.teleTab.getTelegrafCardLabelPopupListItem(name, item)); - } - - async verifyTelegrafCardLabelPillIsVisible(name, item){ - await this.assertVisible(await this.teleTab.getTelegrafCardLabelPillItem(name, item)); - } - - async verifyTelegrafCardLabelPillNotPresent(name, label){ - await this.assertNotPresent(telegrafsTab.getTelegrafCardLabelPillItemSelector(name, label)); - } - - async verifyTelegrafCardLabelListEmptyMsg(name){ - await this.assertVisible(await this.teleTab.getTelegrafCardLabelEmptyState(name)); - } - - async hoverTelegrafCardLabelPill(name, label){ - await this.hoverOver(await this.teleTab.getTelegrafCardLabelPillItem(name, label)); - } - - async clickTelegrafCardLabelPillDelete(name, label){ - await this.clickAndWait(await this.teleTab.getTelegrafCardLabelPillDelete(name, label)); - } - -} - -module.exports = telegrafsSteps; diff --git a/e2e/src/steps/loadData/tokensSteps.js b/e2e/src/steps/loadData/tokensSteps.js deleted file mode 100644 index 3cb3670eee..0000000000 --- a/e2e/src/steps/loadData/tokensSteps.js +++ /dev/null @@ -1,323 +0,0 @@ -const { By, Key } = require('selenium-webdriver'); -const{ expect } = require('chai'); - -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const tokensTab = require(__srcdir + '/pages/loadData/tokensTab.js'); - -const adminPermissions = ['authorizations', - 'buckets', - 'dashboards', - 'sources', - 'tasks', - 'telegrafs', - 'users-admin', - 'variables', - 'scrapers', - 'secrets', - 'labels', - 'views', - 'documents']; - -class tokensSteps extends baseSteps{ - - constructor(driver){ - super(driver); - this.tknTab = new tokensTab(driver); - } - - async isLoaded(){ - await this.tknTab.isTabLoaded(); - } - - async verifyTokenInListByDescr(descr){ - await this.assertVisible(await this.tknTab.getTokenCellByDescr(descr)); - } - - async clickGenerateTokenDropdown(){ - await this.clickAndWait(await this.tknTab.getGenerateTokenDropdownBtn()); // todo better wait - } - - async clickGenerateTokenItem(item){ - await this.clickAndWait(await this.tknTab.getGenerateTokenItem(item), - async () => {await this.driver.sleep(1000);}); //todo better wait - } - - async verifyGenReadWriteTokenPopup(){ - await this.assertVisible(await this.tknTab.getPopupTitle()); - await this.assertVisible(await this.tknTab.getPopupDismiss()); - await this.assertVisible(await this.tknTab.getPopupCancel()); - await this.assertVisible(await this.tknTab.getPopupSave()); - await this.assertVisible(await this.tknTab.getDescrInput()); - await this.assertVisible(await this.tknTab.getTypeRadioButton('Read', 'Scoped')); - await this.assertVisible(await this.tknTab.getTypeRadioButton('Read', 'All Buckets')); - await this.assertVisible(await this.tknTab.getTypeRadioButton('Write', 'Scoped')); - await this.assertVisible(await this.tknTab.getTypeRadioButton('Write', 'All Buckets')); - await this.assertVisible(await this.tknTab.getSearchBuckets('Read')); - await this.assertVisible(await this.tknTab.getSearchBuckets('Write')); - await this.verifyElementContainsText(await this.tknTab.getPopupTitle(), 'Generate Read/Write Token'); - } - - async verifyAllAccessTokenPopup(){ - await this.assertVisible(await this.tknTab.getPopupTitle()); - await this.assertVisible(await this.tknTab.getPopupDismiss()); - await this.assertVisible(await this.tknTab.getAllAccessCancelButton()); - await this.assertVisible(await this.tknTab.getAllAccessSaveButton()); - await this.assertVisible(await this.tknTab.getAllAccessDescrInput()); - await this.assertVisible(await this.tknTab.getPopupAlert()); - await this.verifyElementContainsText(await this.tknTab.getPopupTitle(), 'Generate All Access Token'); - await this.verifyPopupAlertMatchesRegex(/^This token will be able to .* to anything in this organization$/); - } - - async clickModeScopeRadioButton(mode, set){ - await this.clickAndWait(await this.tknTab.getTypeRadioButton(mode, set)); - } - - async verifyPanelEmptyState(mode){ - await this.assertVisible(await this.tknTab.getEmptyStateText(mode)); - } - - async verifyBucketSelectorVisible(mode){ - await this.assertVisible(await this.tknTab.getSearchBuckets(mode)); - } - - async verifyBucketSelectorNotPresent(mode){ - await this.assertNotPresent(await tokensTab.getSearchBucketsSelector(mode)); - } - - async verifyEmptyStateTextNotPresent(mode){ - await this.assertNotPresent(await tokensTab.getEmptyStateTextSelector(mode)); - } - - async verifyPanelBucketList(mode, buckets){ - let buckArr = buckets.split(','); - // console.log("DEBUG buckArr " + buckArr); - for(let i = 0; i < buckArr.length; i++){ - // console.log("DEBUG selector " + JSON.stringify(tokensTab.getSearchBucketsListItemSelector(mode, buckArr[i])) ); - await this.assertVisible(await this.tknTab.getSearchBucketsListItem(mode, buckArr[i])); - } - } - - async verifyPanelBucketsNotPresent(mode, buckets){ - let buckArr = buckets.split(','); - for(let i = 0; i < buckArr.length; i++){ - await this.assertNotPresent(await tokensTab.getSearchBucketsListItemSelector(mode, buckArr[i])); - } - } - - async filterPanelBucketsSelector(mode, term){ - await this.tknTab.getSearchBuckets(mode).then(async elem => { - await this.clearInputText(elem).then(async () => { - await elem.sendKeys(term).then(async () => { - this.delay(150); //todo better wait - }); - }); - }); - } - - async clearPanelBucketsSelector(mode){ - await this.clearInputText(await this.tknTab.getSearchBuckets(mode)); - } - - async clickSelectAllBuckets(mode){ - await this.clickAndWait(await this.tknTab.getSelectAllBuckets(mode)); - } - - async clickDeselectAllBuckets(mode){ - await this.clickAndWait(await this.tknTab.getDeselectAllBuckets(mode)); - } - - async clickTokenPopupSelectBucket(mode, bucket){ - await this.clickAndWait(await this.tknTab.getSearchBucketsListItem(mode, bucket)); - } - - async verifyPanelBucketsSelected(mode, buckets){ - let buckArr = buckets.split(','); - for(let i = 0; i < buckArr.length; i++){ - await this.verifyElementContainsClass( - await this.tknTab.getSearchBucketsListItem(mode, buckArr[i]), - 'selected'); - } - } - - async verifyPanelBucketsNotSelected(mode, buckets){ - let buckArr = buckets.split(','); - for(let i = 0; i < buckArr.length; i++){ - await this.verifyElementDoesNotContainClass( - await this.tknTab.getSearchBucketsListItem(mode, buckArr[i]), - 'selected'); - } - } - - async clickAllAccessPopupCancel(){ - await this.clickAndWait(await this.tknTab.getAllAccessCancelButton(), - //popup seems slow to disappear - async () => { this.driver.sleep(2000);}); //todo better wait - } - - async setAllAccessTokenDescription(descr){ - await this.tknTab.getAllAccessDescrInput().then(async input => { - await input.sendKeys(descr).then(async () => { - await this.delay(150); //todo better wait - }); - }); - } - - async setReadWriteTokenDescription(descr){ - await this.tknTab.getDescrInput().then(async input => { - await input.sendKeys(descr).then(async () => { - await this.delay(150); //todo better wait - }); - }); - } - - async clickGenerateTokenAllAccessSave(){ - await this.clickAndWait(await this.tknTab.getAllAccessSaveButton()); // todo better wait - } - - async clickGenerateTokenReadWriteSave(){ - await this.clickAndWait(await this.tknTab.getPopupSave()); // todo better wait - } - - async disableTokenInList(descr){ - await this.clickAndWait(await this.tknTab.getTokenCardDisableToggle(descr)); - } - - async enableTokenInList(descr){ - await this.clickAndWait(await this.tknTab.getTokenCardDisableToggle(descr)); - } - - async verifyTokenIsDisabled(descr){ - await this.verifyElementDoesNotContainClass( - await this.tknTab.getTokenCardDisableToggle(descr), - 'active'); - } - - async verifyTokenIsEnabled(descr){ - await this.verifyElementContainsClass( - await this.tknTab.getTokenCardDisableToggle(descr), - 'active'); - } - - async verifyTokenSortOrder(list){ - let listArr = list.split(','); - let descrArr = await this.tknTab.getTokenCardDescriptions(); - for(let i = 0; i < listArr.length; i++){ - await descrArr[i].getText(async descrText => { - expect(descrText).to.equal(listArr[i]); - }); - } - } - - async clickTokensSorterButton(){ - await this.clickAndWait(await this.tknTab.getTokenSorterButton()); - } - - async clickTokensSorterItem(item){ - await this.clickAndWait(await this.tknTab.getTokenSorterItem(item)); - } - - async clickTokensSortByName(){ - await this.clickAndWait(await this.tknTab.getTokensSortByDescription()); - } - - async hoverOverTokenDescription(descr){ - await this.hoverOver(await this.tknTab.getTokenDescription(descr)); - } - - async clickTokenDescriptionEditToggle(descr){ - await this.clickAndWait(await this.tknTab.getTokenDescriptionEditBtn(descr)); - } - - async clearTokenDescriptionInput(descr){ - await this.clearInputText(await this.tknTab.getTokenDescriptionEditInput(descr)); - } - - async resetTokenDescription(oldDescr, newDescr){ - await this.tknTab.getTokenDescriptionEditInput(oldDescr).then(async input => { - await input.sendKeys(newDescr + Key.ENTER).then(async () => { - await this.delay(150); //todo better wait - }); - }); - } - - async verifyTokenCardNotPresent(descr){ - await this.assertNotPresent(tokensTab.getTokenCellSelectorByDescr(descr)); - } - - async clickTokenDescription(descr){ - await this.clickAndWait(await this.tknTab.getTokenDescription(descr)); - } - - async verifyReviewTokenPopupLoaded(){ - await this.assertVisible(await this.tknTab.getPopupTitle()); - await this.assertVisible(await this.tknTab.getPopupDismiss()); - await this.assertVisible(await this.tknTab.getPopupCopyToClipboard()); - await this.assertVisible(await this.tknTab.getTokenReviewPermissions()); - } - - async verifyReviewTokenBucketsAllPrivileges(){ - let privArr = ['read','write']; - for(let i = 0; i < adminPermissions.length; i++){ - await this.tknTab.getTokenReviewPermissionItem(adminPermissions[i]) - .then(async elem => { - for( let j = 0; j < privArr.length; j++){ - await this.assertVisible(await - elem.findElement( - By.xpath(`//*[@data-testid='permissions--item']/label[text()='${privArr[j]}']`))); - } - }); - } - - //and finally the orgs-<bucket> read item - // 24.01.20 - this section no longer present - //await this.tknTab.getTokenReviewPermissionItem(`orgs-${__defaultUser.bucket}`) - // .then(async elem => { - // await this.assertVisible(await elem - // .findElement(By.xpath('//*[@data-testid=\'permissions--item\']/label[text()=\'read\']'))); - // }); - - } - - async verifyReviewTokenBuckets(buckets, privileges){ - if(privileges.toLowerCase() === 'all'){ - await this.verifyReviewTokenBucketsAllPrivileges(); - return; - } - let bucketsArr = buckets.split(','); - let privArr = privileges.split(','); - let item = 'buckets'; - for(let i = 0; i < bucketsArr.length; i++){ - if(bucketsArr[i].toLowerCase() !== 'all'){ - item = item + '-' + bucketsArr[i]; - } - await this.tknTab.getTokenReviewPermissionItem(item) - .then(async elem => { - for( let j = 0; j < privArr.length; j++){ - await this.assertVisible(await - elem.findElement( - By.xpath(`//*[@data-testid='permissions--item']/label[text()='${privArr[j]}']`))); - } - }); - } - } - - async hoverOverTokenCard(descr){ - await this.hoverOver(await this.tknTab.getTokenCellByDescr(descr)); - } - - async clickTokenCardDeleteButton(descr){ - await this.clickAndWait(await this.tknTab.getTokenCardDeleteButton(descr)); - } - - //Deprecated -- todo clean - async clickTokenCardDeleteConfirm(descr){ - console.log('This function is deprecated: tokensSteps.clickTokenCardDeleteConfirm(descr)'); - await this.clickAndWait(await this.tknTab.getTokenCardDeleteConfirm(descr)); - } - - async clickTokenCardPopoverDeleteConfirm(){ - await this.clickAndWait(await this.tknTab.getTokenCardPopoverDeletConfirm()); - } -} - -module.exports = tokensSteps; diff --git a/e2e/src/steps/monitoring/checkEditSteps.js b/e2e/src/steps/monitoring/checkEditSteps.js deleted file mode 100644 index 2e3de17ee1..0000000000 --- a/e2e/src/steps/monitoring/checkEditSteps.js +++ /dev/null @@ -1,308 +0,0 @@ -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const checkEditPage = require(__srcdir + '/pages/monitoring/checkEditPage.js'); -const basePage = require(__srcdir + '/pages/basePage.js'); - -const { expect } = require('chai'); - -class checkEditSteps extends influxSteps { - - constructor(driver) { - super(driver); - this.ckEdPage = new checkEditPage(__wdriver); - } - - async isLoaded() { - await this.ckEdPage.isLoaded(); - } - - async verifyIsLoaded() { - await this.assertVisible(await this.ckEdPage.getPageCheckEditTitle()); - await this.assertVisible(await this.ckEdPage.getQueriesToggle()); - await this.assertVisible(await this.ckEdPage.getConfigureCheckToggle()); - } - - async verifyIsNotLoaded(){ - await this.assertNotPresent(checkEditPage.getOverlaySelector()); - } - - async clickCKEdSaveButton(){ - await this.clickAndWait(await this.ckEdPage.getSaveCellButton(), async () => { - await this.driver.sleep(500); //todo - better wait - can be slow to load - }); - } - - async dismissOverlay(){ - await this.clickAndWait(await this.ckEdPage.getDismissButton()); - } - - - async enterAlertCheckName(name){ - await this.clickAndWait(await this.ckEdPage.getPageCheckEditTitle()); - await this.clearInputText(await this.ckEdPage.getPageCheckEditTitleInput()); - await this.typeTextAndWait(await this.ckEdPage.getPageCheckEditTitleInput(), name); - } - - async verifyEditCheckName(name){ - await this.verifyElementContainsText(await this.ckEdPage.getPageCheckEditTitle(), name); - } - - async clickCkEdConfigureCheck(){ - await this.clickAndWait(await this.ckEdPage.getConfigureCheckToggle(), async () => { - await this.driver.sleep(500); // slow to load? - }); - } - - async clickDefineQuery(){ - await this.clickAndWait(await this.ckEdPage.getDefineQueryToggle()); - } - - async verifyConfigureCheckStepLoaded(){ - //Properties - await this.assertVisible(await this.ckEdPage.getConfChkIntervalInput()); - await this.assertVisible(await this.ckEdPage.getConfChkOffset()); - await this.assertVisible(await this.ckEdPage.getConfChkAddTagButton()); - //Message Template - await this.assertVisible(await this.ckEdPage.getConfChkMessageTextArea()); - //Thresholds - await this.assertVisible(await this.ckEdPage.getConfChkAddThresholdButton('CRIT')); - await this.scrollElementIntoView(await this.ckEdPage.getConfChkAddThresholdButton('WARN')); - await this.scrollElementIntoView(await this.ckEdPage.getConfChkAddThresholdButton('INFO')); - await this.scrollElementIntoView(await this.ckEdPage.getConfChkAddThresholdButton('OK')); - //Checklist - await this.assertVisible(await this.ckEdPage.getChecklistPopover()); - } - - async verifyChecklistPopoverItems(items){ - let itemList = JSON.parse(items); - for(const item of itemList){ - - await this.verifyElementContainsClass(await this.ckEdPage.getChecklistPopoverItemByText(item.text), - `${item.state}`); - } - } - - async verifyConfigureCheckListPopoverNotPresent(){ - await this.assertNotPresent(await basePage.getpopoverDialogSelector()); - } - - async verifySaveCheckDisabled(){ - await this.verifyElementDisabled(await this.ckEdPage.getSaveCellButton()); - } - - async verifySaveCheckEnabled(){ - await this.verifyElementEnabled(await this.ckEdPage.getSaveCellButton()); - } - - async clickCkEdIntervalInput(){ - await this.clickAndWait(await this.ckEdPage.getConfChkIntervalInput()); - } - - async setCheckIntervalInput(duration){ - await this.clearInputText(await this.ckEdPage.getConfChkIntervalInput()); - await this.typeTextParanoAndWait(await this.ckEdPage.getConfChkIntervalInput(), duration); - } - - async verifyCkEdIntervalInput(duration){ - await this.verifyElementAttributeContainsText(await this.ckEdPage.getConfChkIntervalInput(), - 'value', duration ); - } - - async verifyCkEdOffsetInput(val){ - await this.verifyElementAttributeContainsText(await this.ckEdPage.getConfChkOffset(), - 'value', val ); - } - - async clickCkEdOffsetInput(){ - await this.clickAndWait(await this.ckEdPage.getConfChkOffset()); - } - - async setCheckOffsetInput(val){ - await this.clearInputText(await this.ckEdPage.getConfChkOffset()); - await this.typeTextParanoAndWait(await this.ckEdPage.getConfChkOffset(), val); - } - - async enterIntoIntervalOffset(offset){ - await this.clearInputText(await this.ckEdPage.getConfChkOffset()); - await this.typeTextParanoAndWait(await this.ckEdPage.getConfChkOffset(), offset); - } - - async verifyCkEdHintDropdownNotVisible(){ - await this.assertNotPresent(await basePage.getDropdownContentsSelector()); - } - - async verifyCkEdHintDropdownItems(items){ - let itemList = items.split(','); - for(const item of itemList){ - let elem = await this.ckEdPage.getDropdownItemByText(item) - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async clickCkEdHintDropdownItem(item){ - await this.scrollElementIntoView(await this.ckEdPage.getDropdownItemByText(item)); - await this.clickAndWait(await this.ckEdPage.getDropdownItemByText(item)); - } - - async updateChecMessageTemplateContent(content){ - //await this.clearInputText(await this.ckEdPage.getConfChkMessageTextArea()); - (await this.ckEdPage.getConfChkMessageTextArea()).clear(); - await this.typeTextAndWait(await this.ckEdPage.getConfChkMessageTextArea(), content); - } - - async verifyCheckMessageTemplateContent(content){ - await this.verifyElementText(await this.ckEdPage.getConfChkMessageTextArea(), content) - } - - async clickAddThresholdCondition(threshold){ - await this.clickAndWait(await this.ckEdPage.getConfChkAddThresholdButton(threshold)) - } - - async clickThresholdDefinitionDropdown(threshold){ - await this.clickAndWait(await this.ckEdPage.getConfNthThresholdDefDropdownButton(threshold)) - } - - async verifyThresholdDefinitionDropdownItems(threshold, items){ - let itemList = items.split(','); - for(const item of itemList){ - let elem = await this.ckEdPage.getConfNthThresholdDefDropdownItem(threshold,item); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async clickThresholdDefinitionDropdownItem(threshold, item){ - await this.clickAndWait(await this.ckEdPage.getConfNthThresholdDefDropdownItem(threshold,item)) - } - - async setUnaryThresholdBoundaryValue(threshold, val1){ - await this.clearInputText(await this.ckEdPage.getConfNthThresholdDefInput(threshold)); - await this.typeTextParanoAndWait(await this.ckEdPage.getConfNthThresholdDefInput(threshold), val1); - } - - async verifyBinaryThresholdBoundaryValues(threshold, lower, upper){ - await this.verifyElementAttributeContainsText(await this.ckEdPage.getConfNthThresholdDefInput(threshold), 'value', lower); - await this.verifyElementAttributeContainsText(await this.ckEdPage.getConfNthThreshold2ndInput(threshold), 'value', upper); - } - - async verifyUnaryThresholdBoundaryValue(threshold, val){ - await this.verifyElementAttributeContainsText(await this.ckEdPage.getConfNthThresholdDefInput(threshold), 'value', val); - } - - async setBinaryThresholdBoundaryValues(threshold, lower, upper){ - await this.clearInputText(await this.ckEdPage.getConfNthThresholdDefInput(threshold)); - await this.typeTextAndWait(await this.ckEdPage.getConfNthThresholdDefInput(threshold), lower); - await this.clearInputText(await this.ckEdPage.getConfNthThreshold2ndInput(threshold)); - await this.typeTextAndWait(await this.ckEdPage.getConfNthThreshold2ndInput(threshold), upper); - } - - async clickNoValuesForDurationInput(){ - await this.clickAndWait(await this.ckEdPage.getConfDeadmanForInput()); - } - - async setValueNoValuesForDurationInput(val){ - await this.clearInputText(await this.ckEdPage.getConfDeadmanForInput()); - await this.typeTextAndWait(await this.ckEdPage.getConfDeadmanForInput(), val); - } - - async verifyValueOfNoValuesForDurationInput(val){ - await this.verifyElementAttributeContainsText(await this.ckEdPage.getConfDeadmanForInput(), 'value', val) - } - - async verifyNoValuesForDurationHintItems(items){ - let itemList = items.split(','); - for(const item of itemList){ - let elem = await this.ckEdPage.getConfDeadmanForInputDropdownItem(item.trim()); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async clickNoValuesForDurationHintItem(item){ - let elem = await this.ckEdPage.getConfDeadmanForInputDropdownItem(item.trim()); - await this.scrollElementIntoView(elem); - await this.clickAndWait(elem); - } - - async clickDefinitionLevelDropdown(){ - await this.clickAndWait(await this.ckEdPage.getConfDeadmanCheckLevelsDropdown()); - } - - async verifyDefinitionLevelDropdownItems(items){ - let itemList = items.split(','); - for(const item of itemList){ - let elem = await this.ckEdPage.getConfDeadmanCheckLevelsDropodownItem(item.trim()); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async clickDefinitionLevelDropdownItem(item){ - let elem = await this.ckEdPage.getConfDeadmanCheckLevelsDropodownItem(item.trim()); - await this.scrollElementIntoView(elem); - await this.clickAndWait(elem); - } - - async verifyDefinitionLevelDropdownSelected(val){ - await this.verifyElementText(await this.ckEdPage.getConfDeadmanCheckLevelsDropdownSelected(), val); - } - - async clickStopCheckingDurationInput(){ - await this.clickAndWait(await this.ckEdPage.getConfDeadmanStopInput()); - } - - async verifyDefinitionStopDropdownItems(items){ - let itemList = items.split(','); - for(const item of itemList){ - let elem = await this.ckEdPage.getConfDeadmanStopInputDropdownItem(item.trim()); - await this.scrollElementIntoView(elem); - await this.assertVisible(elem); - } - } - - async clickDefinitionStopDropdownItem(item){ - let elem = await this.ckEdPage.getConfDeadmanStopInputDropdownItem(item.trim()); - await this.scrollElementIntoView(elem); - await this.clickAndWait(elem); - } - - async verifyDefinitionStopInputValue(val){ - await this.verifyElementAttributeContainsText(await this.ckEdPage.getConfDeadmanStopInput(), - 'value', val) - } - - async setValueDefinitionStopInput(val){ - await this.clearInputText(await this.ckEdPage.getConfDeadmanStopInput()); - await this.typeTextParanoAndWait(await this.ckEdPage.getConfDeadmanStopInput(), val); - }; - - async verifyCellEditPreviewThresholdMarkers(markers){ - let markerList = markers.split(','); - for(const marker of markerList){ - await this.assertVisible(await this.ckEdPage.getPreviewThresholdHandleByLevel(marker.trim())); - } - } - - async clickAddTag(){ - await this.scrollElementIntoView(await this.ckEdPage.getConfChkAddTagButton()); - await this.clickAndWait(await this.ckEdPage.getConfChkAddTagButton()) - } - - async setCheckTagKey(index, key){ - await this.clearInputText(await this.ckEdPage.getConfTagRuleKeyInputOfTag(index)); - await this.typeTextAndWait(await this.ckEdPage.getConfTagRuleKeyInputOfTag(index), key); - } - - async setCheckTagVal(index, val){ - await this.clearInputText(await this.ckEdPage.getConfTagRuleValueInputOfTag(index)); - await this.typeTextAndWait(await this.ckEdPage.getConfTagRuleValueInputOfTag(index), val); - } - - async removeCheckTag(index){ - await this.scrollElementIntoView(await this.ckEdPage.getConfTagRuleDimissOfTag(index)); - await this.clickAndWait(await this.ckEdPage.getConfTagRuleDimissOfTag(index)) - } - -} - -module.exports = checkEditSteps; diff --git a/e2e/src/steps/monitoring/checkStatusHistorySteps.js b/e2e/src/steps/monitoring/checkStatusHistorySteps.js deleted file mode 100644 index 896a4a63fb..0000000000 --- a/e2e/src/steps/monitoring/checkStatusHistorySteps.js +++ /dev/null @@ -1,198 +0,0 @@ -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const checkStatusHistoryPage = require(__srcdir + '/pages/monitoring/checkStatusHistoryPage.js'); -const expect = require('chai').expect; - -const graphAxesStoreName = 'historyGraphAxes'; -const graphContentStoreName = 'historyGraphContent'; - -class checkStatusHistorySteps extends influxSteps { - - constructor(driver) { - super(driver); - this.ckHistPage = new checkStatusHistoryPage(__wdriver); - } - - async isLoaded() { - await this.ckHistPage.isLoaded(); - } - - async verifyIsLoaded() { - await this.assertVisible(await this.ckHistPage.getAlertHistoryTitle()); - await this.assertVisible(await this.ckHistPage.getFilterInput()); - await this.assertVisible(await this.ckHistPage.getCanvasGraphAxes()); - await this.assertVisible(await this.ckHistPage.getCanvasGraphContent()); - await this.assertVisible(await this.ckHistPage.getEventTable()); - } - - async verifyMinimumEvents(count){ - await this.ckHistPage.getEventRows().then(async rows => { - expect(rows.length).to.be.at.least(parseInt(count)); - }).catch(async e => { - console.warn('Caught error looking for events ' + JSON.stringify(e)); - throw e; - }); - } - - async verifyEventName(index, name){ - await this.verifyElementContainsText(await this.ckHistPage.getEventRowCheckNameField(index), name) - } - - async clickEventName(index){ - await this.clickAndWait(await this.ckHistPage.getEventRowCheckNameField(index), async () => { - await this.driver.sleep(500); //can be slow to load? - }); - } - - async verifyMinimumCountEventsAtLevel(count, level){ - await this.ckHistPage.getEventRowsAtLevel(level.trim()).then(async rows => { - expect(rows.length).to.be.at.least(parseInt(count)); - }).catch(async e => { - console.warn(`Caught error looking for events at level ${level} ${JSON.stringify(e)}`); - throw e; - }) - } - - async clickEventFilterInput(){ - await this.clickAndWait(await this.ckHistPage.getFilterInput()); - } - - async verifyFilterExamplesDropdownVisible(){ - await this.assertVisible(await this.ckHistPage.getEventFilterExamplesDropdown()); - } - - async verifyFilterExamplesDropdownNotVisible(){ - await this.assertNotPresent(await checkStatusHistoryPage.getEventFilterExamplesDropdownSelector()); - } - - async clickAlertHistoryTitle(){ - await this.clickAndWait(await this.ckHistPage.getAlertHistoryTitle()); - } - - async zoomInOnEventMarkers(){ - await this.ckHistPage.getEventMarkers().then(async markers => { - let first = await this.ckHistPage.getEventMarkerByIndex(1); - let last = await this.ckHistPage.getEventMarkerByIndex(markers.length); - //console.log("DEBUG first " + JSON.stringify(await first.getRect())); - //console.log("DEBUG last " + JSON.stringify(await last.getRect())); - //await this.driver.executeScript('arguments[0].style.border=\'3px solid red\'', first); - //await this.driver.executeScript('arguments[0].style.border=\'3px solid red\'', last); - await this.ckHistPage.getCanvasGraphContent().then(async canvas => { - //console.log("DEBUG canvas " + JSON.stringify(await canvas.getRect())); - let action = await this.driver.actions(); - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - //let targetX = parseInt(((rect.width/denom) * numer) + x); - let targetY = parseInt((rect.height / 2) + y); - let targetX1 = (await first.getRect()).x - 2; - - //console.log("DEBUG targetX1 " + targetX1 + ' type: ' + typeof(targetX1)); - await action.move({x: parseInt(targetX1), y: targetY, duration: 500}) - .perform(); - - let action2 = await this.driver.actions(); - let targetX2 = (await last.getRect()).x + 2; - - await action2.press() - .move({x: parseInt(targetX2), y: targetY, duration: 500}) - .release() - .perform(); - - await this.driver.sleep(200); // todo better wait - let graph update - }) - }) - } - - async getEventsHistoryGraph(){ - await this.ckHistPage.getCanvasGraphAxes().then(async canvasAxes => { - if(typeof __dataBuffer.graphCellAxes === 'undefined') { - __dataBuffer.graphCellAxes = []; - } - /* eslint-disable require-atomic-updates */ - __dataBuffer.graphCellAxes[graphAxesStoreName] = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - // console.log('DEBUG __dataBuffer.graphCellAxes[' + graphAxesStoreName + "] " + - // __dataBuffer.graphCellAxes[graphAxesStoreName]); - - await this.ckHistPage.getCanvasGraphContent().then(async canvasLine => { - if(typeof __dataBuffer.graphCellLine === 'undefined') { - __dataBuffer.graphCellLine = []; - } - __dataBuffer.graphCellLine[graphContentStoreName] = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - - // console.log('DEBUG __dataBuffer.graphCellLine[' + graphContentStoreName + "] " + - // __dataBuffer.graphCellLine[graphContentStoreName]); - }); - }); - } - - async verifyEventsHistoryGraphChanged(){ - await this.ckHistPage.getCanvasGraphAxes().then(async canvasAxes => { - let currentAxes = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasAxes); - - await expect(currentAxes).to.not.equal(__dataBuffer.graphCellAxes[graphAxesStoreName]); - - await this.ckHistPage.getCanvasGraphContent().then(async canvasLine => { - let currentLine = await this.driver - .executeScript('return arguments[0].toDataURL(\'image/png\');', canvasLine); - await expect(currentLine).to.not.equal(__dataBuffer.graphCellLine[graphContentStoreName]); - }); - }); - - } - - async getEventMarkerTypesAndLocations(){ - await this.ckHistPage.getEventMarkers().then(async markers => { - - __dataBuffer.eventMarkers = []; - - for(let marker of markers){ - //await console.log("DEBUG Marker " + JSON.stringify(await marker.getAttribute('class')) + ' ' - // + JSON.stringify(await marker.getRect())); - let rect = await marker.getRect(); - __dataBuffer.eventMarkers.push({ clazz: await marker.getAttribute('class'), rect: rect }) - } - }); - } - - async verifyEventMarkerLocationChanges(){ - await this.ckHistPage.getEventMarkers().then(async markers => { - for(let i = 0; i < markers.length; i++){ - //await console.log(`DEBUG __dataBuffer.eventMarkers[${i}]: ${JSON.stringify(__dataBuffer.eventMarkers[i])} `); - expect(await markers[i].getAttribute('class')).to.equal(__dataBuffer.eventMarkers[i].clazz); - let rect = await markers[i].getRect(); - expect(rect.x).to.not.equal(__dataBuffer.eventMarkers[i].rect.x) - } - }); - } - - async verifyEventToggleOff(event){ - await this.verifyElementContainsClass(await this.ckHistPage.getEventMarkerToggleByType(event), 'eye-closed'); - } - - async verifyEventToggleOn(event){ - await this.verifyElementContainsClass(await this.ckHistPage.getEventMarkerToggleByType(event), 'eye-open'); - } - - async doubleClickHistoryGraph(){ - await this.ckHistPage.getCanvasGraphContent().then(async canvas => { - let rect = await canvas.getRect(); - let x = parseInt(rect.x); - let y = parseInt(rect.y); - let centX = parseInt((rect.width/2) + x); - let centY = parseInt((rect.height/2) + y); - let action = this.driver.actions(); - await action.move({x: centX, y: centY, duration: 1000}) - .doubleClick() - .perform(); - - await this.driver.sleep(500); //give graph time to redraw - }) - } - -} - -module.exports = checkStatusHistorySteps; diff --git a/e2e/src/steps/monitoring/monitoringSteps.js b/e2e/src/steps/monitoring/monitoringSteps.js deleted file mode 100644 index 2da697a8c0..0000000000 --- a/e2e/src/steps/monitoring/monitoringSteps.js +++ /dev/null @@ -1,254 +0,0 @@ -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const alertsPage = require(__srcdir + '/pages/monitoring/alertsPage.js'); - -class monitoringSteps extends influxSteps{ - - constructor(driver){ - super(driver); - this.alPage = new alertsPage(__wdriver); - } - - async isLoaded(){ - await this.alPage.isLoaded(); - } - - async verifyIsLoaded(){ - await this.assertVisible(await this.alPage.getAlertingTab('checks')); - await this.assertVisible(await this.alPage.getAlertingTab('rules')); - await this.assertVisible(await this.alPage.getAlertingTab('endpoints')); - } - - async verifyNotifyRulesCreateDropdownDiabled(){ - await this.verifyElementDisabled(await this.alPage.getCreateRuleButton()); - } - - async clickAlertingTab(tabName){ - await this.clickAndWait(await this.alPage.getAlertingTab(tabName)); - } - - async clickCreateCheckButton(){ - await this.clickAndWait(await this.alPage.getCreateCheckButton()); - } - - async clickCreateCheckDropdownItem(item){ - await this.clickAndWait(await this.alPage.getCreateCheckDropdownItem(item), async () => { - await this.driver.sleep(500); //slow to load? - }); - } - - async verifyCreateCheckDropdownItems(items){ - let itemList = items.split(','); - for(let i = 0; i < itemList.length; i++){ - await this.assertVisible(await this.alPage.getCreateCheckDropdownItem(itemList[i].trim())); - } - } - - async verifyCreateCheckDropdownNotVisible(){ - await this.assertNotPresent(alertsPage.getCreateCheckDropdownSelector()); - } - - async hoverCreateCheckQMark(){ - await this.hoverOver(await this.alPage.getChecksQuestionMark()); - } - - async verifyCreateCheckTooltipVisible(){ - await this.assertVisible(await this.alPage.getChecksTooltipContents()); - } - - async verifyCreateCheckTooltipNotVisible(){ - await this.assertNotPresent(alertsPage.getChecksTooltipContentsSelector()); - } - - async hoverPageTitle(){ - await this.hoverOver(await this.alPage.getPageTitle()); - } - - async hoverCreateEndpointQMark(){ - await this.hoverOver(await this.alPage.getEndpointsQuestionMark()); - } - - async verifyCreateEndpointTooltipVisible(){ - await this.assertVisible(await this.alPage.getEndpointsTooltipContents()); - } - - async verifyCreateEndpointTooltipNotVisible(){ - await this.assertNotPresent(alertsPage.getEndpointsTooltipContentsSelector()); - } - - async hoverCreateRuleQMark(){ - await this.hoverOver(await this.alPage.getRulesQuestionMark()); - } - - async verifyCreateRuleTooltipVisible(){ - await this.assertVisible(await this.alPage.getRulesTooltipContents()); - } - - async verifyCreateRuleTooltipNotVisible(){ - await this.assertNotPresent(alertsPage.getRulesTooltipContentsSelector()); - } - - async clickCreateEndpointButton(){ - await this.clickAndWait(await this.alPage.getCreateEndpointButton()); - } - - async verifyCreateEndpointPopupLoaded(){ - await this.verifyElementText(await this.alPage.getPopupTitle(),'Create a Notification Endpoint'); - await this.assertVisible(await this.alPage.getEpPopupEndpointDropdownButton()); - await this.assertVisible(await this.alPage.getEpPopupEndpointNameInput()); - await this.assertVisible(await this.alPage.getEpPopupEndpointDescriptionText()); - await this.assertVisible(await this.alPage.getEpPopupCancelButton()); - await this.assertVisible(await this.alPage.getEpPopupSaveButton()); - } - - async clickFirstTimeCreateThresholdCheck(){ - await this.clickAndWait(await this.alPage.getFirstTimeThresholdCheckCreateButton(), async () => { - await this.driver.sleep(500); //can be slow to load - TODO better wait - }); - } - - async verifyFirstTimeCreateThresholdCheckVisible(){ - await this.assertVisible(await this.alPage.getFirstTimeThresholdCheckCreateButton()); - } - - async clickFirstTimeCreateDeadmanCheck(){ - await this.scrollElementIntoView(await this.alPage.getFirstTimeDeadmanCheckCreateButton()); - await this.clickAndWait(await this.alPage.getFirstTimeDeadmanCheckCreateButton()); - } - - async verifyFirstTimeCreateDeadmanCheckVisible(){ - await this.assertVisible(await this.alPage.getFirstTimeDeadmanCheckCreateButton()); - } - - async verifyAlertCardName(name){ - await this.assertVisible(await this.alPage.getCheckCardName(name)); - } - - async hoverOverCheckCardName(name){ - await this.scrollElementIntoView(await this.alPage.getCheckCardName(name)); - await this.hoverOver(await this.alPage.getCheckCardName(name)); - } - - async clickCheckCardName(name){ - let elem = await this.alPage.getCheckCardName(name); - await this.scrollElementIntoView(elem); - await this.clickAndWait(elem); - } - - async clickCheckCardNameEditButton(name){ - await this.clickAndWait(await this.alPage.getCheckCardNameEditButton(name)); - } - - async updateCheckCardActiveNameInput(newVal){ - await this.clearInputText(await this.alPage.getCheckCardNameInput()); - await this.typeTextAndWait(await this.alPage.getCheckCardNameInput(), newVal); - } - - async hoverOverCheckCardDescription(name){ - await this.scrollElementIntoView(await this.alPage.getCheckCardDescription(name)); - await this.hoverOver(await this.alPage.getCheckCardDescription(name)); - } - - async clickCheckCardDescriptionEditButton(name){ - await this.clickAndWait(await this.alPage.getCheckCardDescriptionEditButton(name)); - } - - async updateCheckCardActiveDescription(text){ - await this.clearInputText(await this.alPage.getCheckCardDescriptionInput()); - await this.typeTextAndWait(await this.alPage.getCheckCardDescriptionInput(), text); - } - - async verifyCheckCardDescription(name, text){ - await this.driver.sleep(1500); //card update seems a bit slow - await this.verifyElementContainsText(await this.alPage.getCheckCardDescription(name), text); - } - - async clickCheckCardEmptyLabel(name){ - await this.scrollElementIntoView(await this.alPage.getCheckCardLabelEmpty(name)); - await this.clickAndWait(await this.alPage.getCheckCardLabelEmpty(name)); - } - - async clickChecksFilterInput(){ - await this.clickAndWait(await this.alPage.getChecksFilterInput()); - } - - async clickCheckCardAddLabels(name){ - await this.clickAndWait(await this.alPage.getCheckCardAddLabelButton(name), async () => { - await this.driver.sleep(500); //fetching labels seems slow - }); - } - - async verifyCheckCardLabels(name,labels){ - let labelsList = labels.split(','); - for(const label of labelsList){ - await this.assertVisible(await this.alPage.getCheckCardLabelPill(name, label)); - } - } - - async removeLabelPillFromCheckCard(name,label){ - await this.hoverOver(await this.alPage.getCheckCardLabelPill(name, label)); - await this.clickAndWait(await this.alPage.getCheckCardLabelRemove(name, label)); - } - - async verifyCheckCardDoesNotHaveLabels(name, labels){ - let labelsList = labels.split(','); - for(const label of labelsList){ - await this.assertNotPresent(await alertsPage.getCheckCardLabelPillSelector(name, label)); - } - } - - async clickCheckCardCloneButton(name){ - await this.clickAndWait(await this.alPage.getCheckCardCloneButton(name)); - } - - async clickCheckCardCloneConfirm(name){ - await this.clickAndWait(await this.alPage.getCheckCardCloneConfirm(name)); - } - - async verifyCheckCardsVisible(names){ - let namesList = names.split(','); - for(const name of namesList){ - await this.assertVisible(await this.alPage.getCheckCardName(name.trim())); - } - } - - async verifyCheckCardsNotPresent(names){ - let namesList = names.split(','); - for(const name of namesList){ - await this.assertNotPresent(await alertsPage.getCheckCardNameSelector(name.trim())); - } - } - - async enterValueToCheckCardsFilter(value){ - let elem = await this.alPage.getChecksFilterInput(); - await this.clearInputText(elem); - await this.typeTextAndWait(elem, value); - } - - async clearCheckCardsFilter(){ - await this.clearInputText(await this.alPage.getChecksFilterInput()); - } - - async verifyEmptyChecksStateMessage(col, message){ - await this.verifyElementContainsText(await this.alPage.getEmptyStateColumnText(col), message); - } - - async clickCheckCardOpenHistory(name){ - await this.clickAndWait(await this.alPage.getCheckCardOpenHistory(name)); - } - - async clickCheckCardOpenHistoryConfirm(name){ - await this.clickAndWait(await this.alPage.getCheckCardOpenHistoryConfirm(name)); - } - - async clickCheckCardDelete(name){ - await this.clickAndWait(await this.alPage.getCheckCardDeleteButton(name.trim())); - } - - async clickCheckCardDeleteConfirm(name){ - await this.clickAndWait(await this.alPage.getCheckCardDeleteConfirm(name.trim())); - } - - -} - -module.exports = monitoringSteps; diff --git a/e2e/src/steps/onboarding/onboardingSteps.js b/e2e/src/steps/onboarding/onboardingSteps.js deleted file mode 100644 index 81869e09fc..0000000000 --- a/e2e/src/steps/onboarding/onboardingSteps.js +++ /dev/null @@ -1,147 +0,0 @@ -const expect = require('chai').expect; -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const splashPage = require(__srcdir + '/pages/onboarding/splashPage.js'); -const initialSetupPage = require(__srcdir + '/pages/onboarding/initialSetupPage.js'); -const readyPage = require(__srcdir + '/pages/onboarding/readyPage.js'); -const influxPage = require(__srcdir + '/pages/influxPage.js'); -const bucketsTab = require(__srcdir + '/pages/loadData/bucketsTab.js'); - - -class onboardingSteps extends baseSteps { - - constructor(driver){ - super(driver); - this.splashPage = new splashPage(driver); - this.initialSetupPage = new initialSetupPage(driver); - this.readyPage = new readyPage(driver); - this.influxPage = new influxPage(driver); - this.bucketsTab = new bucketsTab(driver); - } - - async open(){ - this.spashPage.open(); - } - - async verifyHeadContains(text){ - - await this.splashPage.getHeadMain().then(elem => { - elem.getText().then(eltxt => { - expect(eltxt) - .to - .include(text); - }); - }); - } - - async verifyCreditsLink(){ - await this.splashPage.getCreditsLink().then( elem => { - elem.getText().then( eltxt => { - expect(eltxt).to.equal('InfluxData'); - }); - - elem.getAttribute('href').then(href => { - expect(href).to.equal('https://www.influxdata.com/'); - }); - }); - } - - async clickStart(){ - await this.splashPage.getStartButton().then( async elem => { - await elem.click(); - await this.splashPage.waitUntilElementCss('h3.wizard-step--title '); - }); - } - - async verifySetupHeaderContains(text){ - await this.initialSetupPage.getHeaderMain().then(elem => { - elem.getText().then( async eltxt => { - await expect(eltxt).to.include(text); - }); - }); - } - - async verifyNavCrumbText(crumb, text){ - await this.initialSetupPage.getCrumbStep(crumb).then( async elem => { - await elem.getText().then(async eltxt => { - await expect(eltxt).to.include(text); - }); - }); - - } - - async setInputFieldValue(field, value){ - await this.initialSetupPage.getInputField(field).then( async elem => { - await this.clearInputText(elem); - //await elem.clear(); - await elem.sendKeys(value); - // await this.delay(3000) - }); - } - - async clickContinueButton(chkReadyPage = true){ - await this.initialSetupPage.getNextButton().then(async btn => { - await btn.click(); - if(chkReadyPage) { - await this.readyPage.isLoaded(); - } - }).catch(async err => { - console.log(err); - }); - } - - async verifySubtitle(){ - await this.readyPage.getSubtitle().then( async subt => { - await subt.getText().then( async subtxt => { - await expect(subtxt).to.include('1 organization'); - await expect(subtxt).to.include('1 user'); - await expect(subtxt).to.include('1 bucket'); - }); - }); - } - - async verifyNavCrumbTextColor(crumb, color){ - await this.initialSetupPage.getCrumbStep(crumb).then( async elem => { - await elem.getCssValue('color').then(async cssColor => { - await expect(cssColor).to.include(color); - }); - }); - } - - async clickQuickStartButton(){ - await this.readyPage.getQuickStartButton().then(async btn =>{ - await btn.click(); - await this.influxPage.isLoaded(); - //await this.driver.sleep(1000) //for some reason if no wait here next page load throws error - }); - } - - async clickAdvancedButton(){ - await this.readyPage.getAdvancedButton().then(async btn =>{ - await btn.click(); - await this.influxPage.isLoaded(); - }); - } - - async verifyFormErrorMessage(message){ - await this.initialSetupPage.getFormErrorMessage().then(async elem => { - await elem.getText().then( eltxt => { - expect(eltxt).to.equal(message); - }); - }); - } - - async verifyFormErrorMessageNotPresent(){ - expect(await this.initialSetupPage.isFormErrorDisplayed()).to.be.false; - } - - async verifyContinueButtonDisabled(){ - expect(await this.initialSetupPage.isNextButtonEnabled()).to.be.false; - } - - async failTest(){ - await expect(true).to.be.false; - } - -} - -module.exports = onboardingSteps; diff --git a/e2e/src/steps/organization/organizationSteps.js b/e2e/src/steps/organization/organizationSteps.js deleted file mode 100644 index 5ef5296a47..0000000000 --- a/e2e/src/steps/organization/organizationSteps.js +++ /dev/null @@ -1,29 +0,0 @@ -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const organizationPage = require(__srcdir + '/pages/organization/organizationPage.js'); - - -class organizationSteps extends influxSteps{ - - constructor(driver){ - super(driver); - this.orgPage = new organizationPage(__wdriver); - } - - async isLoaded(){ - await this.orgPage.isLoaded(); - } - - async verifyIsLoaded(){ - // this.assertVisible(await this.setPage.getTabByName('Members')); no longer on page commit=bd91a81123 build_date=2020-04-07T07:57:22Z - // this.assertVisible(await this.setPage.getTabByName('Buckets')); moved to new load data page - // this.assertVisible(await this.setPage.getTabByName('Telegraf')); ditto - // this.assertVisible(await this.setPage.getTabByName('Scrapers')); ditto - this.assertVisible(await this.orgPage.getTabByName('Members')); - this.assertVisible(await this.orgPage.getTabByName('About')); - // this.assertVisible(await this.setPage.getTabByName('Tokens')); // tokens no longer part of settings - // this.assertVisible(await this.setPage.getTabByName('About')); no longer on page commit=bd91a81123 build_date=2020-04-07T07:57:22Z - } - -} - -module.exports = organizationSteps; \ No newline at end of file diff --git a/e2e/src/steps/settings/labelsSteps.js b/e2e/src/steps/settings/labelsSteps.js deleted file mode 100644 index 718458db65..0000000000 --- a/e2e/src/steps/settings/labelsSteps.js +++ /dev/null @@ -1,244 +0,0 @@ -const { expect } = require('chai'); - -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const labelsTab = require(__srcdir + '/pages/settings/labelsTab.js'); - -let colorMap = new Map([ - ['thunder', '#FFD255'], - ['topaz', '#E85B1C'] -]); - -class labelsSteps extends baseSteps{ - - constructor(driver){ - super(driver); - this.labTab = new labelsTab(driver); - } - - async isLoaded(){ - await this.labTab.isTabLoaded(); - } - - async verifyCreateLabelPopupLoaded(){ - await this.verifyElementContainsText(await this.labTab.getPopupTitle(), 'Create Label'); - await this.assertVisible(await this.labTab.getPopupDismiss()); - await this.assertVisible(await this.labTab.getLabelPopupNameInput()); - await this.assertVisible(await this.labTab.getLabelPopupDescrInput()); - await this.assertVisible(await this.labTab.getLabelPopupColorPicker()); - await this.assertVisible(await this.labTab.getLabelPopupColorInput()); - await this.assertVisible(await this.labTab.getLabelPopupCreateBtn()); - await this.assertVisible(await this.labTab.getLabelPopupCancelBtn()); - } - - async verifyEditLabelPopuLoaded(){ - await this.verifyElementContainsText(await this.labTab.getPopupTitle(), 'Edit Label'); - await this.assertVisible(await this.labTab.getPopupDismiss()); - await this.assertVisible(await this.labTab.getLabelPopupNameInput()); - await this.assertVisible(await this.labTab.getLabelPopupDescrInput()); - await this.assertVisible(await this.labTab.getLabelPopupColorPicker()); - await this.assertVisible(await this.labTab.getLabelPopupColorInput()); - await this.assertVisible(await this.labTab.getLabelPopupCreateBtn()); - await this.assertVisible(await this.labTab.getLabelPopupCancelBtn()); - } - - async dismissCreateLabelPopup(){ - await this.clickAndWait(await this.labTab.getPopupDismiss()); - } - - async cancelCreateLabelPopup(){ - await this.clickAndWait(await this.labTab.getLabelPopupCancelBtn(), - async () => { await this.delay(1000);}); //can be slow to remove - todo better wait - } - - async clickCreateLabelButtonEmpty(){ - await this.clickAndWait(await this.labTab.getCreateLabelEmpty()); //todo better wait - } - - async clickCreateLabelButtonHeader(){ - await this.clickAndWait(await this.labTab.getCreateLabelHeader()); //todo better wait - } - - // value is hex value eg '#EAC8A2' - static hexColorValueToDecimalArray(value){ - value = value.slice(1); - let values = value.match(/.{1,2}/g); - for(let i = 0; i < values.length; i++){ - values[i] = parseInt(values[i], 16); - } - return values; - } - - // value needs to follow pattern 'rgba(255,255,255,1)' - static rgbaColorValueToDecimalArray(value){ - value = value.replace('rgba(', ''); - value = value.replace(')', ''); - let values = value.split(','); - values.pop(); - for(let i = 0; i < values.length; i++){ - values[i] = parseInt(values[i], 10); - } - return values; - } - - async verifyInputColorMatchesPreview(){ - await this.labTab.getLabelPopupColorInput().then(async input => { - let values = labelsSteps.hexColorValueToDecimalArray(await input.getAttribute('value')); - //console.log("DEBUG input color " + values); - await this.labTab.getLabelPopupPreview().then(async elem => { - let bkgcols = await elem.getCssValue('background-color'); - let bkgVals = labelsSteps.rgbaColorValueToDecimalArray(bkgcols); - for(let i = 0; i < bkgVals.length; i++){ - await expect(bkgVals[i]).to.equal(values[i]); - } - }); - - }); - } - - async verifyLabelPopupPreviewTextColor(value){ - let values = labelsSteps.hexColorValueToDecimalArray(value); - //console.log("DEBUG values " + values); - await this.labTab.getLabelPopupPreviewPill().then(async elem => { - let colors = await elem.getCssValue('color'); - let colVals = labelsSteps.rgbaColorValueToDecimalArray(colors); - for(let i = 0; i < colVals.length; i++){ - await expect(colVals[i]).to.equal(values[i]); - } - }); - } - - async verifyCreateLabelPreviewPillText(text){ - await this.verifyElementContainsText(await this.labTab.getLabelPopupPreviewPill(), text); - } - - async typeCreateLabelPopupName(text){ - await this.typeTextAndWait(await this.labTab.getLabelPopupNameInput(), text); - } - - async typeCreateLabelPopupDescription(descr){ - await this.typeTextAndWait(await this.labTab.getLabelPopupDescrInput(), descr); - } - - - async clearLabelPopupColorInput(){ - await this.clearInputText(await this.labTab.getLabelPopupColorInput()); - } - - async clearLabelPopupNameInput(){ - await this.clearInputText(await this.labTab.getLabelPopupNameInput()); - } - - async clearLabelPopupDescriptionInput(){ - await this.clearInputText(await this.labTab.getLabelPopupDescrInput()); - } - - - async typeCreateLabelPopupColor(value){ - await this.typeTextAndWait(await this.labTab.getLabelPopupColorInput(), value, - async () => { await this.delay(500); }); //preview can be slow to update - todo better wait - } - - async clickLabelPopupLuckyColor(){ - await this.clickAndWait(await this.labTab.getLabelPopupRandomColor(), - async () => { await this.delay(500); }); // preview can be slow to update - todo better wait - } - - async verifyLabelPopupColorInputValue(value){ - await this.verifyInputEqualsValue(await this.labTab.getLabelPopupColorInput(), value); - } - - async verifyLabelPopupColorInputNotValue(value){ - await this.verifyInputDoesNotContainValue(await this.labTab.getLabelPopupColorInput(), value); - } - - async clickLabelPopupColorSwatch(name){ - await this.clickAndWait(await this.labTab.getLabelPopupColorSwatch(name), - async () => { await this.delay(500); }); // preview can be slow to update - todo better wait - } - - async clickLabelPopupCreateButton(){ - await this.clickAndWait(await this.labTab.getLabelPopupCreateBtn(), - async () => { await this.delay(1000); }); //popup can be slow to close - } - - async verifyLabelCardInList(name){ - await this.assertVisible(await this.labTab.getLabelCard(name)); - } - - - - async verifyLabelCardPillColor(name, color){ - await this.delay(333); //animation changes can take a split second - //console.log("DEBUG color " + color) - if(color[0] !== '#'){ - color = colorMap.get(color.toLowerCase()); - // console.log("DEBUG color switched " + color) - } - - let values = labelsSteps.hexColorValueToDecimalArray(color); - await this.labTab.getLabelCardPill(name).then(async elem => { - let pillBkgColor = await elem.getCssValue('background-color'); - let pillVals = labelsSteps.rgbaColorValueToDecimalArray(pillBkgColor); - // console.log("DEBUG pillVals " + pillVals); - // console.log("DEBUG values " + values); - for(let i = 0; i < pillVals.length; i++){ - expect(pillVals[i]).to.equal(values[i]); - } - }); - } - - async verifyLabelCardDescription(name, descr){ - await this.verifyElementContainsText(await this.labTab.getLabelCardDescr(name), descr); - } - - async clickLabelCardPill(name){ - await this.clickAndWait(await this.labTab.getLabelCardPill(name)); - } - - async verifyLabelSortOrder(labels){ - let lblArr = labels.split(','); - await this.labTab.getLabelCardPills().then(async pills => { - for(let i = 0; i < lblArr.length; i++){ - await expect(await pills[i].getText()).to.equal(lblArr[i]); - } - }); - } - - async clickLabelSortByName(){ - await this.clickAndWait(await this.labTab.getLabelNameSort()); - } - - async clickLabelSortByDescription(){ - await this.clickAndWait(await this.labTab.getLabelDescSort()); - } - - async clearLabelFilterInput(){ - await this.clearInputText(await this.labTab.getLabelsFilter()); - } - - async enterTextIntoLabelFilter(text){ - await this.typeTextAndWait(await this.labTab.getLabelsFilter(), text); - } - - async verifyLabelsNotPresent(labels){ - let lblArr = labels.split(','); - for(let i = 0; i < lblArr.length; i++){ - await this.assertNotPresent(labelsTab.getLabelCardSelector(lblArr[i])); - } - } - - async hoverOverLabelCard(name){ - await this.hoverOver(await this.labTab.getLabelCard(name)); - } - - async clickLabelCardDelete(name){ - await this.clickAndWait(await this.labTab.getLabelCardDelete(name)); - } - - async clickLabelCardDeleteConfirm(name){ - await this.clickAndWait(await this.labTab.getLabelCardDeleteConfirm(name)); - } - -} - -module.exports = labelsSteps; diff --git a/e2e/src/steps/settings/membersSteps.js b/e2e/src/steps/settings/membersSteps.js deleted file mode 100644 index 4c913e5386..0000000000 --- a/e2e/src/steps/settings/membersSteps.js +++ /dev/null @@ -1,17 +0,0 @@ -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const membersTab = require(__srcdir + '/pages/settings/membersTab.js'); - -class membersSteps extends baseSteps{ - - constructor(driver){ - super(driver); - this.memTab = new membersTab(driver); - } - - async isLoaded(){ - await this.memTab.isTabLoaded(); - } - -} - -module.exports = membersSteps; diff --git a/e2e/src/steps/settings/orgProfileSteps.js b/e2e/src/steps/settings/orgProfileSteps.js deleted file mode 100644 index 066d87351f..0000000000 --- a/e2e/src/steps/settings/orgProfileSteps.js +++ /dev/null @@ -1,17 +0,0 @@ -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const orgProfileTab = require(__srcdir + '/pages/settings/orgProfileTab.js'); - -class orgProfileSteps extends baseSteps{ - - constructor(driver){ - super(driver); - this.opTab = new orgProfileTab(driver); - } - - async isLoaded(){ - await this.opTab.isTabLoaded(); - } - -} - -module.exports = orgProfileSteps; diff --git a/e2e/src/steps/settings/settingsSteps.js b/e2e/src/steps/settings/settingsSteps.js deleted file mode 100644 index fd3d6f8eae..0000000000 --- a/e2e/src/steps/settings/settingsSteps.js +++ /dev/null @@ -1,36 +0,0 @@ -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const settingsPage = require(__srcdir + '/pages/settings/settingsPage.js'); - -class settingsSteps extends influxSteps{ - - constructor(driver){ - super(driver); - this.setPage = new settingsPage(__wdriver); - } - - async isLoaded(){ - await this.setPage.isLoaded(); - } - - async verifyIsLoaded(){ - // this.assertVisible(await this.setPage.getTabByName('Members')); no longer on page commit=bd91a81123 build_date=2020-04-07T07:57:22Z - // this.assertVisible(await this.setPage.getTabByName('Buckets')); moved to new load data page - // this.assertVisible(await this.setPage.getTabByName('Telegraf')); ditto - // this.assertVisible(await this.setPage.getTabByName('Scrapers')); ditto - this.assertVisible(await this.setPage.getTabByName('Variables')); - this.assertVisible(await this.setPage.getTabByName('Templates')); - this.assertVisible(await this.setPage.getTabByName('Labels')); - // this.assertVisible(await this.setPage.getTabByName('Tokens')); // tokens no longer part of settings - // this.assertVisible(await this.setPage.getTabByName('About')); no longer on page commit=bd91a81123 build_date=2020-04-07T07:57:22Z - } - - async clickTab(name){ - if(name.toLowerCase() === 'profile'){ //fix one non-matching case - name = 'About'; - } - await (await this.setPage.getTabByName(name)).click(); - } - -} - -module.exports = settingsSteps; diff --git a/e2e/src/steps/settings/templatesSteps.js b/e2e/src/steps/settings/templatesSteps.js deleted file mode 100644 index 081fbbc73f..0000000000 --- a/e2e/src/steps/settings/templatesSteps.js +++ /dev/null @@ -1,145 +0,0 @@ -const { expect } = require('chai'); -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const templatesTab = require(__srcdir + '/pages/settings/templatesTab.js'); -const influxUtils = require(__srcdir + '/utils/influxUtils.js'); - -class templatesSteps extends baseSteps{ - - constructor(driver){ - super(driver); - this.tmTab = new templatesTab(driver); - } - - async isLoaded(){ - await this.tmTab.isTabLoaded(); - } - - async verifyTemplateCardsSort(templates){ - let tempArray = templates.split(','); - await this.tmTab.getTemplateCardNames().then(async cards => { - for(let i = 0; i < tempArray.length; i++){ - expect(await cards[i].getText()).to.equal(tempArray[i]); - } - }); - } - - async verifyImportTemplatePopupLoaded(){ - await this.assertVisible(await this.tmTab.getImportTemplateUploadButton()); - await this.assertVisible(await this.tmTab.getImportTemplatePasteButton()); - await this.assertVisible(await this.tmTab.getImportTemplateSubmitButton()); - await this.assertVisible(await this.tmTab.getPopupDismiss()); - await this.assertVisible(await this.tmTab.getPopupFileUploadHeader()); - await this.verifyElementContainsText(await this.tmTab.getPopupTitle(), 'Import Template'); - } - - async verifyImportTemplateFileUpload(present){ - if(present){ - await this.assertPresent(await this.tmTab.getPopupFileUploadSelector()); - }else{ - await this.assertNotPresent(await this.tmTab.getPopupFileUploadSelector()); - } - } - - async verifyImportTemplatePasteJSON(present){ - if(present){ - await this.assertPresent(await templatesTab.getImportTemplateJSONTextAreaSelector()); - }else{ - await this.assertNotPresent(await templatesTab.getImportTemplateJSONTextAreaSelector()); - } - } - - async clickUserTemplatesButton(){ - await this.clickAndWait(await this.tmTab.getUserTemplatesRadioButton()); - } - - async clickImportTemplateEmptyButton(){ - await this.clickAndWait(await this.tmTab.getImportTemplateEmptyButton()); - } - - async verifyImportTemplatePopupSubmitEnabled(enabled){ - if(enabled){ - await this.verifyElementEnabled(await this.tmTab.getImportTemplateSubmitButton()); - }else{ - await this.verifyElementDisabled(await this.tmTab.getImportTemplateSubmitButton()); - } - } - - async clickImportTemplateHeaderButton(){ - await this.clickAndWait(await this.tmTab.getImportTemplateHeaderButton(), - //seems to be overrunning ui response - async () => { this.driver.sleep(1500);}); //todo better wait - } - - async clickImportTemplatePasteButton(){ - await this.clickAndWait(await this.tmTab.getImportTemplatePasteButton(), - async () => { this.driver.sleep(1500);}); //todo better wait - } - - async clickImportTemplateUploadButton(){ - await this.clickAndWait(await this.tmTab.getImportTemplateUploadButton()); - } - - async enterTextImportTemplateJSON(text){ - await this.typeTextAndWait(await this.tmTab.getImportTemplateJSONTextArea(), text); - } - - //todo fix file separator in path below - async uploadTemplateFile(filePath){ - await this.tmTab.getImportTemplateDragNDrop().then(async elem => { - await elem.sendKeys(process.cwd() + '/' + filePath).then(async () => { - await this.delay(200); //debug wait - todo better wait - }); - }); - } - - async clickImportTemplateSubmitButton(){ - await this.clickAndWait(await this.tmTab.getImportTemplateSubmitButton()); - } - - async verifyTemplateCardVisibility(name){ - await this.assertVisible(await this.tmTab.getTemplateCardByName(name)); - } - - async copyFileContentsToTemplateTextare(filepath){ - await this.copyFileContentsToTextarea(filepath, await this.tmTab.getImportTemplateJSONTextArea()); - } - - async verifyRESTTemplateDocumentExists(user,title){ - //let uzzer = await influxUtils.getUser(user); - let resp = await influxUtils.getDocTemplates(user); - let match = resp.documents.filter( doc => doc.meta.name === title); - expect(match.length).to.be.above(0); - } - - async enterTemplatesFilterValue(value){ - await this.typeTextAndWait(await this.tmTab.getTemplatesFilter(), value); - } - - async verifyTemplateNotPresent(name){ - await this.assertNotPresent(await templatesTab.getTemplateCardSelectorByName(name)); - } - - async clearTemplatesFilter(){ - await this.clearInputText(await this.tmTab.getTemplatesFilter()); - } - - async clickSortTemplatesByName(){ - await this.clickAndWait(await this.tmTab.getNameSort()); - } - - async hoverOverTemplateCard(name){ - await this.hoverOver(await this.tmTab.getTemplateCardByName(name)); - } - - async clickTemplateContextDelete(name){ - await this.clickAndWait(await this.tmTab.getTemplateCardCtxDelete(name)); - } - - async clickTemplateDeleteConfirm(name){ - await this.clickAndWait(await this.tmTab.getTemplateCardDeleteConfirm(name), async () => { - await this.driver.sleep(1000); // todo better wait - occasional overrun - }); - } -} - -module.exports = templatesSteps; diff --git a/e2e/src/steps/settings/variablesSteps.js b/e2e/src/steps/settings/variablesSteps.js deleted file mode 100644 index 44f8b83fdf..0000000000 --- a/e2e/src/steps/settings/variablesSteps.js +++ /dev/null @@ -1,348 +0,0 @@ -const { By } = require('selenium-webdriver'); -const { expect } = require('chai'); -const path = require('path'); -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const variablesTab = require(__srcdir + '/pages/settings/variablesTab.js'); - -class variablesSteps extends baseSteps{ - - constructor(driver){ - super(driver); - this.varTab = new variablesTab(driver); - } - - async isLoaded(){ - await this.varTab.isTabLoaded(); - } - - async clickCreateVariableDropdown(){ - await this.clickAndWait(await this.varTab.getCreateVariableHeader()); - } - - async clickCreateVariableDropdownEmpty(){ - await this.clickAndWait(await this.varTab.getCreateVariableEmpty()); - } - - async clickCreateVariableDropdownItem(item){ - await this.clickAndWait(await this.varTab.getCreateVariableItem(item), - //over running this step? - async () => { await this.driver.sleep(1000); }); // todo better wait - } - - async verifyImportVariablePopupLoaded(){ - await this.assertVisible(await this.varTab.getPopupDismiss()); - await this.assertVisible(await this.varTab.getUploadRadioButton()); - await this.assertVisible(await this.varTab.getPasteRadioButton()); - await this.assertPresent(await variablesTab.getDragNDropFileSelector()); //N.B. display: none - await this.assertVisible(await this.varTab.getImportButton()); - await this.verifyElementContainsText(await this.varTab.getPopupTitle(), 'Import Variable'); - } - - async verifyCreateVariablePopupLoaded(){ - await this.assertVisible(await this.varTab.getPopupDismiss()); - await this.assertVisible(await this.varTab.getPopupCancelSimple()); - //await this.assertVisible(await this.varTab.getPopupCreate()); - await this.assertVisible(await this.varTab.getCreateVarPopupCreateButton()); - await this.assertVisible(await this.varTab.getCreateVariableNameInput()); - await this.assertVisible(await this.varTab.getCreateVariableTypeDropdown()); - await this.verifyElementContainsText(await this.varTab.getPopupTitle(), 'Create Variable'); - } - - async verifyEditVariablePopupLoaded(){ - await this.assertVisible(await this.varTab.getPopupDismiss()); - await this.assertVisible(await this.varTab.getPopupCancelSimple()); - await this.assertVisible(await this.varTab.getPopupSubmit()); - await this.assertVisible(await this.varTab.getCreateVariableNameInput()); - await this.assertVisible(await this.varTab.getEditVariableTypeDropdown()); - await this.verifyElementContainsText(await this.varTab.getPopupTitle(), 'Edit Variable'); - } - - async verifyVariableNameChangeWarningPopupLoaded(){ - await this.assertVisible(await this.varTab.getPopupDismiss()); - await this.assertVisible(await this.varTab.getEditVariablWarnSubmit()); - await this.verifyElementContainsText(await this.varTab.getPopupTitle(), 'Are you sure?'); - await this.varTab.getEditVariablWarnSubmit().then(async elem => { - await this.verifyElementContainsText(await elem.findElement(By.xpath('./span')), - 'I understand, let\'s rename my Variable'); - }); - } - - async clickImportPopupPasteJSON(){ - await this.clickAndWait(await this.varTab.getPasteRadioButton()); - } - - async verifyImportPopupJSONTextareaVisible(visible){ - if(visible){ - await this.assertVisible(await this.varTab.getPasteJSONTextarea()); - }else{ - await this.assertNotPresent(variablesTab.getPasteJSONTextareaSelector()); - } - } - - async verifyImportPopupImportJSONButtonEnabled(enabled) { - if (enabled) { - await this.verifyElementEnabled(await this.varTab.getImportButton()); - }else{ - await this.verifyElementDisabled(await this.varTab.getImportButton()); - } - } - - async clickImportPopupUploadFile(){ - await this.clickAndWait(await this.varTab.getUploadRadioButton()); - } - - async verifyImportPopupFileUploadPresent(){ - await this.assertPresent(await variablesTab.getDragNDropFileSelector()); - } - - async verifyCreateVarPopupSelectedType(type){ - await this.varTab.getCreateVariableTypeDropdown().then(async elem => { - await this.verifyElementText(await elem.findElement(By.css('[class*=selected]')), type); - }); - } - - async verifyCreatePopupCreateEnabled(enabled){ - if(enabled) { - await this.verifyElementEnabled(await this.varTab.getCreateVarPopupCreateButton()); - }else{ - await this.verifyElementDisabled(await this.varTab.getCreateVarPopupCreateButton()); - } - } - - async verifyCreateVarPopupQueryEditorVisible(visible){ - if(visible){ - //await this.assertVisible(await this.varTab.getCreateVariableQueryCodeMirror()); - await this.assertVisible(await this.varTab.getCreateVariableQueryMonacoEdit()); - }else{ - //await this.assertNotPresent(await variablesTab.getCreateVariableQueryCodeMirrorSelector()); - await this.assertNotPresent(await variablesTab.getCreateVariableQueryMonacoEditSelector()); - } - } - - async clickCreateVariableTypeDropdown(){ - await this.clickAndWait(await this.varTab.getCreateVariableTypeDropdown(), - //seems to be slow - async () => { this.driver.sleep(1000); }); //todo better wait - } - - async clickEditVariableTypeDropdown(){ - await this.clickAndWait(await this.varTab.getEditVariableTypeDropdown()); - } - - async clickCreateVarPopupTypeDropdownItem(item){ - await this.clickAndWait(await this.varTab.getCreateVariableTypeDropdownItem(item)); - } - - async clickEditVarPopupTypeDropdownItem(item){ - await this.clickAndWait(await this.varTab.getEditVariableTypeDropdownItem(item)); - } - - async verifyCreateVarPopupTextareaVisible(visible){ - if(visible){ - await this.assertVisible(await this.varTab.getCreateVariableTextArea()); - }else{ - await this.assertNotPresent(variablesTab.getCreateVariableTextAreaSelector()); - } - } - - async verifyCreateVarPopupDefaultValDropdownVisible(visible){ - if(visible){ - await this.assertVisible(await this.varTab.getCreateVariableDefaultValDropdown()); - }else{ - await this.assertNotPresent(variablesTab.getCreateVariableDefaultValDropdownSelector()); - } - } - - async verifyCreateVarPopupInfoCount(count){ - await this.varTab.getCreateVariableInfoPara().then(async elem => { - await elem.getText().then(async elText=> { - // e.g. "Mapping Contains 0 key-value pairs" - let tokens = elText.split(' '); - expect(parseInt(tokens[2])).to.equal(parseInt(count)); - }); - }); - } - - async verifyCreateVarPopupInfoVisible(visible){ - if(visible){ - await this.assertVisible(await this.varTab.getCreateVariableInfoPara()); - }else{ - await this.assertNotPresent(variablesTab.getCreateVariableInfoParaSelector()); - } - } - - async uploadImportVarPopupFile(path2file){ - await this.varTab.getDragNDropFile().then(async elem => { - await elem.sendKeys(process.cwd() + '/' + path2file).then(async () => { - await this.delay(200); //debug wait - todo better wait - }); - }); - } - - async verifyImportPopupUploadSuccess(){ - await this.verifyElementContainsClass(await this.varTab.getImportVariableDragNDropHeader(), 'selected'); - } - - async verifyImportPopupUploadFilename(path2file){ - let fp = path.parse(path2file); - await this.verifyElementContainsText(await this.varTab.getImportVariableDragNDropHeader(), fp.base); - } - - async clickImportPopupImportButton(){ - await this.clickAndWait(await this.varTab.getImportButton(), async () => { - await this.delay(1500); //lengthen a bit - sometimes slow to import - todo better wait - }); - } - - async verifyVariableCardVisible(name){ - await this.assertVisible(await this.varTab.getVariableCardNamed(name)); - } - - async enterCreateVarPopupName(name){ - await this.typeTextAndWait(await this.varTab.getCreateVariableNameInput(), name); - } - - async clearCreateVarPopupName(){ - await this.clearInputText(await this.varTab.getCreateVariableNameInput()); - } - - async enterCreateVarPopupTextarea(values){ - await this.typeTextAndWait(await this.varTab.getCreateVariableTextArea(), values); - } - - async verifyCreatePopupDefaultValDropdownSelected(item){ - await this.varTab.getCreateVariableDefaultValDropdown().then(async elem => { - await elem.findElement(By.css('[class*=\'selected\']')).then(async el2 => { - await this.verifyElementContainsText(el2, item); - }); - }); - } - - async clickCreateVarPopupDefaultDropdown(){ - await this.clickAndWait(await this.varTab.getCreateVariableDefaultValDropdown()); - } - - async clickCreateVarPopupDefaultDropdownItem(item){ - await this.clickAndWait(await this.varTab.getCreateVariableDefaultValDropdownItem(item)); - } - - async clickCreatVarPopupDefaultCSVDropdownItem(item){ - await this.clickAndWait(await this.varTab.getCreateVariableDefaultValCSVDropdownItem(item)); - } - - async clickCreateVarPopupCreateButton(){ - await this.clickAndWait(await this.varTab.getCreateVarPopupCreateButton()); - } - - async clickEditVarPopupSubmitButton(){ - await this.clickAndWait(await this.varTab.getPopupSubmit()); - } - - async setVariablePopupCodeMirrorText(text){ - await this.setCodeMirrorText(await this.varTab.getCreateVariableQueryCodeMirror(), text); - } - - async setVariablePopupMonacoEditText(text){ - await this.setMonacoEditorText(await this.driver.findElement(By.css('.monaco-editor .inputarea')), - text); - } - - async enterValueIntoVariablesFilter(value){ - await this.typeTextAndWait(await this.varTab.getVariablesFilter(), value); - } - - async verifyVariableCardsVisible(cards){ - let cardsArr = cards.split(','); - for(let i = 0; i < cardsArr.length; i++){ - await this.assertVisible(await this.varTab.getVariableCardNamed(cardsArr[i])); - } - } - - async verifyVariablsCardsNotPresent(cards){ - let cardsArr = cards.split(','); - for(let i = 0; i < cardsArr.length; i++){ - await this.assertNotPresent(await variablesTab.getVariableCardSelectorByName(cardsArr[i])); - } - } - - async verifyVariableCardsSort(cards){ - let cardsArr = cards.split(','); - await this.varTab.getVariableCardNames().then(async cardNames => { - for(let i = 0; i < cardsArr.length; i++){ - expect(await cardNames[i].getText()).to.equal(cardsArr[i]); - } - }); - } - - async clickVariableSortByName(){ - await this.clickAndWait(await this.varTab.getNameSort()); - } - - async clearVariablesFilter(){ - await this.clearInputText(await this.varTab.getVariablesFilter()); - } - - async clickVariableCardName(name){ - await this.clickAndWait(await this.varTab.getVariableCardName(name)); - } - - async hoverOverVariableCard(name){ - await this.hoverOver(await this.varTab.getVariableCardNamed(name)); - } - - async clickVariableCardContextMenu(name){ - await this.clickAndWait(await this.varTab.getVariableCardContextMenu(name)); - } - - async clickVariableCardContextMenuItem(name,item){ - await this.clickAndWait(await this.varTab.getVariableCardContextMenuItem(name, item), - //troubleshoot occasional overrun - async () => { await this.driver.sleep(2000); } ); //todo better wait - } - - async clickVariableNameChangeWarningUnderstand(){ - await this.clickAndWait(await this.varTab.getEditVariablWarnSubmit(), - //occasional overrun at this point - async () => { await this.driver.sleep(2000); }); //todo better wait - } - - async clearVariableNameChangeNameInput(){ - await this.clearInputText(await this.varTab.getUpdateNameNameInput()); - } - - async enterNewVariableName(name){ - await this.typeTextAndWait(await this.varTab.getUpdateNameNameInput(), name); - } - - async verifyChangeVariableNameSubmitDisabled(){ - await this.verifyElementDisabled(await this.varTab.getEditVariableNameChangeSubmit()); - } - - async clickSubmitRenameVariablePopup(){ - await this.clickAndWait(await this.varTab.getEditVariableNameChangeSubmit()); - } - - async verifyEditVariablePopupNameDisabled(){ - await this.verifyElementContainsAttribute(await this.varTab.getEditVariableNameInput(), 'disabled'); - } - - async verifyEditVariablePopupTextareaCleared(){ - await this.verifyElementContainsNoText(await this.varTab.getCreateVariableTextArea()); - } - - async clickVariableCardDelete(name){ - await this.clickAndWait(await this.varTab.getVariableCardContextDelete(name)); - } - - async clickVariableCardDeleteConfirm(name){ - await this.clickAndWait(await this.varTab.getVariableCardContextDeleteConfirm(name)); - } - - async verifyVariableCardNotPresent(name){ - await this.assertNotPresent(await variablesTab.getVariableCardSelectorByName(name)); - } -} - - - -module.exports = variablesSteps; diff --git a/e2e/src/steps/signin/signinSteps.js b/e2e/src/steps/signin/signinSteps.js deleted file mode 100644 index 5c3da4364f..0000000000 --- a/e2e/src/steps/signin/signinSteps.js +++ /dev/null @@ -1,119 +0,0 @@ -const expect = require('chai').expect; -const {By, until, error} = require('selenium-webdriver'); -const baseSteps = require(__srcdir + '/steps/baseSteps.js'); -const signinPage = require(__srcdir + '/pages/signin/signinPage.js'); -const influxPage = require(__srcdir + '/pages/influxPage.js'); - -class signinSteps extends baseSteps { - - constructor(driver){ - super(driver); - this.signinPage = new signinPage(driver); - this.influxPage = new influxPage(driver); - } - - async verifyHeadingContains(text){ - expect(await (await this.signinPage.getHeading()).getText()).to.include(text); - } - - async verifyHeading(){ - await this.assertVisible(await this.signinPage.getInfluxLogo()); - } - - async verifyVersionContains(version){ - expect(await (await this.signinPage.getVersionInfo()).getText()).to.include(version); - } - - async verifyCreditsLink(){ - await this.signinPage.getCreditsLink().then( elem => { - elem.getText().then( eltxt => { - expect(eltxt).to.equal('InfluxData'); - }); - - elem.getAttribute('href').then(href => { - expect(href).to.equal('https://www.influxdata.com/'); - }); - }); - } - - async verifyIsLoaded(){ - this.assertVisible(await this.signinPage.getInfluxLogo()); - this.assertVisible(await this.signinPage.getNameInput()); - this.assertVisible(await this.signinPage.getPasswordInput()); - this.assertVisible(await this.signinPage.getSigninButton()); - //this.assertVisible(await this.signinPage.getCreditsLink()); - } - - async enterUsername(name){ - await this.signinPage.getNameInput().then(async input => { - await input.clear(); - await input.sendKeys(name); - }).catch(async err => { - console.error("ERROR on input user name: " + err); - if(err instanceof error.StaleElementReferenceError){ // try again - console.warn("WARNING retrying input username") -// await this.driver.sleep(3000); // - await this.driver.wait(until.elementIsVisible(await this.signinPage.getNameInput())); - await this.signinPage.getNameInput().then(async input => { - await input.clear(); - await input.sendKeys(name); - }) - } - throw err; - }); - } - - async enterPassword(password){ - await this.signinPage.getPasswordInput().then(async input =>{ - await input.clear(); - await input.sendKeys(password); - }).catch(async err => { - console.log("ERROR on input user password: " + err); - if(err instanceof error.StaleElementReferenceError) { // try again - console.warn("WARNING retrying input password"); -// await this.driver.sleep(3000); // - await this.driver.wait(until.elementIsVisible(await this.signinPage.getPasswordInput())); - await this.signinPage.getPasswordInput().then(async input =>{ - await input.clear(); - await input.sendKeys(password); - }) - } - throw err; - }); - } - - async clickSigninButton(){ - await this.signinPage.getSigninButton().then(async btn =>{ - await btn.click(); - }).catch(async err => { - console.error("ERROR on click signin button: " + err); - if(err instanceof error.StaleElementReferenceError) { //try again - console.warn("WARNING retrying click signin"); -// await this.driver.sleep(3000); // - await this.driver.wait(until.elementIsVisible(await this.signinPage.getSigninButton())); - await this.signinPage.getSigninButton().then(async btn =>{ - await btn.click(); - }) - } - throw err; - }); - } - - async waitForSigninToLoad(timeout){ - await this.driver.wait(until.elementIsVisible(await this.signinPage.getNameInput()), timeout, - `Waited ${timeout} milliseconds to locate signin name input`); - await this.driver.wait(until.elementIsVisible(await this.signinPage.getPasswordInput()), timeout, - `Waited ${timeout} milliseconds to locate signin password input`); - } - - async signin(user){ - await this.driver.sleep(5000); //work around for stale element when signin page refreshes - await this.enterUsername(user.username); - await this.enterPassword(user.password); - await this.clickSigninButton(); - await this.influxPage.isLoaded(); - } -} - -module.exports = signinSteps; - diff --git a/e2e/src/steps/tasks/tasksSteps.js b/e2e/src/steps/tasks/tasksSteps.js deleted file mode 100644 index 793696bc11..0000000000 --- a/e2e/src/steps/tasks/tasksSteps.js +++ /dev/null @@ -1,33 +0,0 @@ -const influxSteps = require(__srcdir + '/steps/influx/influxSteps.js'); -const tasksPage = require(__srcdir + '/pages/tasks/tasksPage.js'); - -class dashboardsSteps extends influxSteps { - - constructor(driver){ - super(driver); - this.tasksPage = new tasksPage(driver); - } - - async isLoaded(){ - await this.tasksPage.isLoaded(); - } - - async verifyIsLoaded(){ - await this.assertVisible(await this.tasksPage.getFilterTasks()); - await this.assertVisible(await this.tasksPage.getCreateTaskDropdownHeader()); - await this.assertVisible(await this.tasksPage.getInactiveToggle()); - await this.assertVisible(await this.tasksPage.getSortTypeButton()); - //this.assertVisible(await this.tasksPage.getNameSortButton()); - //this.assertVisible(await this.tasksPage.getActiveSortButton()); - //this.assertVisible(await this.tasksPage.getScheduleSortButton()); - //this.assertVisible(await this.tasksPage.getLastCompetedSortButton()); - await this.assertVisible(await this.tasksPage.getCreateTaskDropdownBody()); - } - - async verifyTaskCardVisible(name){ - await this.assertVisible(await this.tasksPage.getTaskCardByName(name)); - } - -} - -module.exports = dashboardsSteps; diff --git a/e2e/src/utils/htmlReport.js b/e2e/src/utils/htmlReport.js deleted file mode 100755 index 17ec2736ee..0000000000 --- a/e2e/src/utils/htmlReport.js +++ /dev/null @@ -1,20 +0,0 @@ -#!/usr/bin/env node -var reporter = require('cucumber-html-reporter'); - -var options = { - theme: 'bootstrap', - jsonFile: 'report/cucumber_report.json', - output: 'report/cucumber_report.html', - reportSuiteAsScenarios: true, - launchReport: false, - metadata: { - 'App Version':'2.0.0-alpha', - 'Test Environment': 'Develop', - 'Browser': 'Chrome 74', - 'Platform': 'Ubuntu 16.04', - 'Parallel': 'Scenarios', - 'Executed': 'local' - } -}; - -reporter.generate(options); diff --git a/e2e/src/utils/influxUtils.js b/e2e/src/utils/influxUtils.js deleted file mode 100644 index a441f9f027..0000000000 --- a/e2e/src/utils/influxUtils.js +++ /dev/null @@ -1,982 +0,0 @@ -// TBD - leverage influxdbv2 REST API -const process = require('process'); -const axios = require('axios'); -const fs = require('fs'); -const csvParseSync = require('csv-parse/lib/sync'); -const {exec} = require('child_process'); -const util = require('util'); -const exec_prom = util.promisify(exec); - -let active_config = require(__basedir + '/e2e.conf.json').active; -//let config = require(__basedir + '/e2e.conf.json')[active_config]; -let setHeadless = false; -let newHeadless = false; -let selDocker = false; - -let nowNano = new Date().getTime() * 1000000; -let intervalNano = 600 * 1000 * 1000000; //10 min in nanosecs - -const {InfluxDB} = require('@influxdata/influxdb-client'); -const { AuthorizationsAPI, - BucketsAPI, - ChecksAPI, - DashboardsAPI, - DocumentsAPI, - LabelsAPI, - OrgsAPI, - SetupAPI, - VariablesAPI} = require('@influxdata/influxdb-client-apis'); - - -const mil2Nano = 1000000; - -process.argv.slice(2).forEach((val) => { - - let pair = val.split('='); - - switch(pair[0]){ - case 'headless': //overrides value in config file - setHeadless = true; - newHeadless = (pair[1] === 'true'); - // Need to pop our args out, otherwise they will interfere with cucumber ArgvParser - process.argv.splice(process.argv.indexOf(val), 1); - break; - case 'sel_docker': - case 'selDocker': - selDocker = (pair[1] === 'true'); - process.argv.splice(process.argv.indexOf(val), 1); - break; - case 'activeConf': - case 'active_conf': - active_config = pair[1]; - process.argv.splice(process.argv.indexOf(val), 1); - break; - } -}); - -const config = require(__basedir + '/e2e.conf.json')[active_config]; -const defaultUser = config.default_user; -config.sel_docker = selDocker; -config.headless = setHeadless ? newHeadless : config.headless; - -global.__config = config; -global.__defaultUser = defaultUser; -global.__users = { 'init': undefined }; -global.__killLiveDataGen = false; -global.__liveDataGenRunning = false; -global.__reportedResetOnce = false; -global.__dockerRun = false; -global.__currentFeature = 'jar'; -global.__currentScenario = 'pickle'; - -if(typeof __config.download_dir === 'undefined'){ - __config.download_dir = __basedir; -} - -console.log(config.headless ? 'running headless' : 'running headed'); -console.log(config.sel_docker ? 'running for selenium in docker' : 'running for selenium standard'); -console.log(`active configuration ${JSON.stringify(config)}`); - -__config.download_dir = __config.download_dir + '/etc/'; -/* -if(typeof process.env['HOSTNAME'] !== 'undefined' && process.env['HOSTNAME'].match(/^[a-f0-9]{12}/)){ - console.log("MATCHED docker style hostname"); - __dockerRun = true; - __config.download_dir = __config.download_dir + '/etc/'; -} -*/ -//redefine any config fields based on ENV Properties of the form E2E_<ACTIVE_CONF>_<FIELD_KEY> -/* -Object.keys(__config).forEach(k => { - let envar = `E2E_${active_config.toUpperCase()}_${k.toUpperCase()}`; - console.log(`${envar}=${process.env[envar]} typeof ${typeof __config[k]}`); - if(typeof process.env[envar] !== 'undefined'){ - console.log('DEBUG redefining var ' + process.env[envar]); - __config[k] = process.env[envar]; - } -}); -*/ - -const resetConfigFieldsToEnvar = (base, o) => { -// console.log(`DEBUG o ${JSON.stringify(o)}`); - Object.keys(o).forEach( k => { - let envar = `${base}_${k.toUpperCase()}`; - switch(typeof o[k]){ - case 'string': - if(typeof process.env[envar] !== 'undefined'){ - console.log(`--- resetting config val ${k} to ${envar} ---`) - o[k] = process.env[envar]; - } - break; - case 'object': - resetConfigFieldsToEnvar(envar, o[k]); - break; - default: //i.e. undefined - //do nothing - break; - } - }) -}; - -resetConfigFieldsToEnvar(`E2E_${active_config.toUpperCase()}`, __config); - -//Need to keep axios for calls to /debug/flush -axios.defaults.baseURL = `${config.influx_url}`; - - -//Object.keys(__config).forEach(k => console.log(`__Config.${k} = ${__config[k]}`)); - -/* Uncomment to debug axios -axios.interceptors.request.use(request => { - console.log('Starting Request', request) - return request -}) - -axios.interceptors.response.use(response => { - console.log('Response:', response) - return response -}) -*/ - -const flush = async () => { - await axios.get('/debug/flush').catch(async error => { - console.log("DEBUG error " + JSON.stringify(error)) - }); - delete global.__users; - global.__users = { 'init': undefined }; -}; - -const removeConfInDocker = async () => { - await exec_prom('docker exec influx2_solo rm /root/.influxdbv2/configs || true'); -}; - -//for compatibility with old test style - until all are updated -const setupUser = async(newUser) => { - - console.warn("WARNING: call to user old style start " + newUser.username); - - if(newUser.username === 'ENV'){ - await resolveUsernameFromEnv(newUser); - } - - - if(newUser.password === 'ENV'){ - await resolvePasswordFromEnv(newUser); - } - - await resolveUserTokenBeforeCreate(newUser); - - await setupUserRest(newUser); - await putUser(newUser); - await __wdriver.sleep(1000); - await setUserOrgId(newUser); - -}; - -const setUserOrgId = async(user) => { - //now grab the first org - let orgsAPI = new OrgsAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000})); - - let orgs = await orgsAPI.getOrgs(); - - user.orgid = orgs.orgs[0].id; -}; - -// user { username: 'name', password: 'password', org; 'orgname', bucket: 'bucketname', token: 'optional_token' } -const setupNewUser = async(newUser) => { - - let user = newUser.toUpperCase() === 'DEFAULT' ? __defaultUser : JSON.parse(newUser); - - if(user.username === 'ENV'){ - await resolveUsernameFromEnv(user); - } - - - if(user.password === 'ENV'){ - await resolvePasswordFromEnv(user); - } - - await resolveUserTokenBeforeCreate(user); - - console.log(`--- preparing to setup user on ${__config.influx_url}`); - - switch(__config.create_method.toUpperCase()){ - case 'REST': - console.log(`--- Creating new User '${user.username}' over REST ---`); - await setupUserRest(user) - break; - case 'CLI_DOCKER': - console.log(`--- Creating new User '${user.username}' with CLI to docker container ${__config.docker_name} ---`); - await setupUserDockerCLI(user); - break; - case 'CLI': - console.log(`--- Creating new user '${user.username}' with CLI using influx CLI client at ${__config.influx_path} ---`); - await setupUserCLI(user); - break; - case "SKIP": - console.log(`Skipping creating user '${user.username}' on target deployment ` + - `at ${__config.host}. User should already exist there` ); - break; - default: - throw `Unknown create user method ${__config.create_method}` - } - - putUser(user); - - await __wdriver.sleep(1000); //give db chance to update before continuing - - await setUserOrgId(user); -}; - -const resolvePasswordFromEnv = async(user) => { - - if(user.password.toUpperCase() === 'ENV'){ - let envar = `E2E_${__config.config_id.toUpperCase()}_DEFAULT_USER_PASSWORD`; - user.password = process.env[envar] - } - -}; - -const resolveUsernameFromEnv = async(user) => { - - if(user.password.toUpperCase() === 'ENV'){ - let envar = `E2E_${__config.config_id.toUpperCase()}_DEFAULT_USER_USERNAME`; - user.username = process.env[envar] - } - -}; - - -const resolveUserTokenBeforeCreate = async(user) => { - if(typeof user.token === 'undefined'){ - return; - } - if(user.token.toUpperCase() === 'ENV'){ - - let envar = `E2E_${__config.config_id.toUpperCase()}_DEFAULT_USER_TOKEN`; - user.token = process.env[envar] - } -}; - -const setupUserRest = async(user) => { - - const setupAPI = new SetupAPI(new InfluxDB(__config.influx_url)); - - setupAPI.getSetup().then(async ({allowed}) => { - - let body = {org: user.org, bucket: user.bucket, username: user.username, password: user.password }; - - if(user.token){ - body.token = user.token; - } - - if(allowed){ - await setupAPI.postSetup({ - body: body, - }); - console.log(`--- Setup user ${user.username} at ${__config.influx_url} success ---`) - }else{ - console.error(`--- Failed to setup user ${user.username} at ${__config.influx_url} ---`); - } - }).catch(async error => { - console.error(`\n--- Setup user ${user.username} ended in ERROR ---`); - console.error(error) - }); -}; - -const setupUserDockerCLI = async(user) => { - - await removeConfInDocker(); - - let command = `docker exec ${__config.docker_name} /usr/bin/influx setup` + - ` --host ${__config.influx_url}` + - ` -o ${user.org} -b ${user.bucket} -u ${user.username} -p ${user.password}`; - if(typeof user.token !== 'undefined'){ - command = command + ` -t ${user.token}`; - } - - command = command + ' -f'; - - await exec_prom(command).catch(async error => { - console.warn(error); - }); -}; - -const setupUserCLI = async(user) => { - - let configsPath = `${process.env.HOME}/.influxdbv2/configs`; - - if(await fs.existsSync(configsPath)){ - await console.log(`--- removing configs ${configsPath} ---`); - await fs.unlink(configsPath, async err => { - if(err) throw err; - await console.log(`--- ${configsPath} deleted ---`); - }) - } - - let command = `${__config.influx_path} setup` + - ` --host ${__config.influx_url}` + - ` -o ${user.org} -b ${user.bucket} -u ${user.username} -p ${user.password}`; - if(typeof user.token !== 'undefined'){ - command = command + ` -t ${user.token}`; - } - - command = command + ' -f'; - - exec(command, async (error, stdout, stderr) => { - if(error){ - await console.error("ERROR: " + error); - } - await console.log(stdout); - if(stderr){ - await console.error(stderr) - } - }); - -}; - -//reserved for future solutions -const setupCloudUser = async(userName) => { - if(__config.config_id !== 'cloud'){ - throw `Attempt to setup cloud user with config ${__config.config_id}` - } - - if(userName.toUpperCase() !== 'DEFAULT'){ - throw `${userName} not handled. Currently only DEFAULT cloud user in e2e.conf.json is handled.` - } -}; - -// user { username: 'name', password: 'password', org; 'orgname', bucket: 'bucketname' } -const putUser = (user) => { - if(!(user.username in __users)){ - __users[user.username] = user; - return; - } - throw `${user.username} already defined in global users`; -}; - -const getUser = (name) => { - - if(name.toUpperCase() === 'DEFAULT'){ - return __users[__defaultUser.username]; - } - - if(name in __users){ - return __users[name]; - } - throw `"${name}" is not a key in global users`; -}; - -//TODO - replace or remove in usages -const signInAxios = async (username) => { - - let user = getUser(username); - return await axios.post('/api/v2/signin', '', {auth: {username: user.username, password: user.password}}).then(async resp => { - //console.log("DEBUG Headers " + JSON.stringify(resp.headers)) - let cookie = resp.headers['set-cookie'][0]; - axios.defaults.headers.common['Cookie'] = cookie; //for axios - //let pair = cookie.split('=') - //let expiry = new Date(Date.now() + (24 * 60 * 60 * 1000)); - //await __wdriver.get(`${__config.protocol}://${__config.host}:${__config.port}/`) // not working even with valid session cookie redirected to login - //await __wdriver.manage().addCookie({name: pair[0], value: pair[1], expiry: expiry, domain: __config.host}); //for selenium - return cookie; - }).catch(err => { - console.log(err); - throw(err); //need to rethrow error - otherwise cucumber will not catch it and test will be success - }); - -}; - -//TODO - replace or remove in usages -const endSession = async() => { - delete axios.defaults.headers.common['Cookie']; -}; - -const writeData = async (userName, //string - lines = ['testmeas value=300 ' + (nowNano - (3 * intervalNano)), - 'testmeas value=200 ' + (nowNano - (2 * intervalNano)), - 'testmeas value=100 ' + (nowNano - intervalNano)]) => { - - let user = await getUser(userName); - - const writeAPI = await new InfluxDB({url: __config.influx_url, token: user.token}) - .getWriteApi(user.org, user.bucket, 'ns'); - - await writeAPI.writeRecords(lines); - - await writeAPI.close().catch(e => { - console.error(`ERROR: closing write connection: ${e}`); - throw e; - }) -}; - -const query = async(userName, //string - query // string -) => { - - let user = await getUser(userName); - - const queryApi = await new InfluxDB({url: __config.influx_url, token: user.token}) - .getQueryApi(user.org); - - //need to return array of strings as result - - let result = []; - - return await new Promise((resolve,reject) => { - queryApi.queryRows(query, { - next(row, tableMeta) { - const o = tableMeta.toObject(row); - result.push(o); - }, - error(error) { - reject(error) - }, - complete() { - resolve(result); - }, - }); - }).catch(async error => { - console.error('Caught Error on Query: ' + error); - throw error; - }); -}; - -// TODO - verify usages with changes using client API -//Parse query result string to Array[Map()] of column items -const parseQueryResults = async(results) => { - let resultsArr = results.split('\r\n,'); - - let resultsMapArr = []; - - let resultsMapKeys = resultsArr[0].split(','); - - resultsMapKeys.shift(); //first element is empty string - - for(let i = 0; i < resultsArr.length; i++){ - if(i === 0){ - continue; - } - resultsMapArr[i-1] = new Map(); - let colVals = resultsArr[i].split(','); - for(let j = 0; j < resultsMapKeys.length; j++){ - await resultsMapArr[i-1].set(resultsMapKeys[j], colVals[j]); - } - } - - return resultsMapArr; -}; - -// TODO - add retentionRules or retention policy rp -//{"name":"ASDF","retentionRules":[],"orgID":"727d19908f30184f","organization":"qa"} -const createBucket = async(orgId, // String - orgName, //String - bucketName, //String -) => { - - bucketAPI = new BucketsAPI(new InfluxDB({url: __config.influx_url, token: __defaultUser.token, timeout: 20000})); - - await bucketAPI.postBuckets({body: {name: bucketName, orgID: orgId}}); -}; - -//TODO - create cell and view to attach to dashboard -const createDashboard = async(name, orgId) => { - const dbdsAPI = new DashboardsAPI(new InfluxDB({url: __config.influx_url, token: __defaultUser.token, timeout: 20000})); - await dbdsAPI.postDashboards({body: {name: name, orgID: orgId}}).catch(async error => { - console.log('--- Error Creating dashboard ---'); - console.error(error); - throw error; - }); -}; - -const getDashboards = async(userName) => { - - let user = getUser(userName); - - const dbdsAPI = new DashboardsAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000})); - - return await dbdsAPI.getDashboards(); -}; - -const getAuthorizations = async(userName) => { - - let user = getUser(userName); - - let authsAPI = new AuthorizationsAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000})); - - return await authsAPI.getAuthorizations(); -}; - -// http://localhost:8086/api/v2/labels -// {"orgID":"8576cb897e0b4ce9","name":"MyLabel","properties":{"description":"","color":"#7CE490"}} -const createLabel = async(userName, - labelName, - labelDescr, - labelColor ) =>{ - - let user = getUser(userName); - - const lblAPI = new LabelsAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000})); - - let lblCreateReq = {body: {name: labelName, orgID: user.orgid, - properties: { description: labelDescr, color: labelColor }}}; - - await lblAPI.postLabels(lblCreateReq).catch(async error => { - console.log('--- Error Creating label ---'); - console.error(error); - throw error; - }); -}; - -const createVariable = async(userName, name, type, values, selected = null ) => { - - let user = getUser(userName); - - let varAPI = new VariablesAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000})); - - let parseValues = JSON.parse(values); - - let reSel = selected === null ? selected : JSON.parse(selected); - - return await varAPI.postVariables({body: {name: name, - orgID: user.orgid, - arguments: { - type: type, - values: parseValues - }, - selected: reSel - } - }) -}; - -const getDocTemplates = async(userName) => { - - let user = getUser(userName); - - let docsAPI = new DocumentsAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000, })); - - return await docsAPI.getDocumentsTemplates({orgID: user.orgid}); -}; - -const createTemplateFromFile = async(userName, filepath) => { - - let user = getUser(userName); - - let docsAPI = new DocumentsAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000})); - - - let content = await readFileToBuffer(process.cwd() + '/' + filepath); - let newTemplate = JSON.parse(content); - newTemplate.orgID = user.orgid; - - docsAPI.postDocumentsTemplates({ body: newTemplate}); -}; - -const createAlertCheckFromFile = async(userName, filepath) => { - - let user = getUser(userName); - - let content = await readFileToBuffer(process.cwd() + '/' + filepath); - - let newCheck = JSON.parse(content); - - newCheck.orgID = user.orgid; - - let chkAPI = new ChecksAPI(new InfluxDB({url: __config.influx_url, token: user.token, timeout: 20000})); - - chkAPI.createCheck({body: newCheck}); -}; - -const writeLineProtocolData = async (userName, def) => { - - let define = JSON.parse(def); - - let dataPoints = []; - let nowMillis = new Date().getTime(); - //line protocol i.e. myMeasurement,host=myHost testField="testData" 1556896326 - let intervals = await getIntervalMillis(define.points, define.start); - let startMillis = nowMillis - intervals.full; - - let samples; - if(define.data === undefined) { - samples = await genPoints(define.algo, define.points); - }else{ - samples = await genPoints(define.algo, define.points, define.data) - } - - if(define.algo === 'dico'){ - for (let i = 0; i < samples.length; i++) { - dataPoints.push(`${define.name},test=generic ${define.measurement}="${samples[i]}" ${(startMillis + (intervals.step * i)) * mil2Nano}\n`); - } - }else { - for (let i = 0; i < samples.length; i++) { - dataPoints.push(`${define.name},test=generic ${define.measurement}=${samples[i]} ${(startMillis + (intervals.step * i)) * mil2Nano}\n`); - } - } - - await writeData(userName, dataPoints); -}; - -// sample def : { "points": 10, "measurement":"level", "start": "-60h", "algo": "hydro", "prec": "sec"} -const genLineProtocolFile = async(filePath, def) => { - let define = JSON.parse(def); - - if(fs.existsSync(filePath)) { - console.log('Removing pre-existing file ' + filePath); - await fs.unlink(filePath, async err => { - if (err) { - console.log('Failed to remove file ' + filePath); - } - }); - } - - let dataPoints = []; - let nowMillis = new Date().getTime(); - //line protocol i.e. myMeasurement,host=myHost testField="testData" 1556896326 - let intervals = await getIntervalMillis(define.points, define.start); - let startMillis = nowMillis - intervals.full; - - let samples - if(define.data === undefined) { - samples = await genPoints(define.algo, define.points); - }else{ - samples = await genPoints(define.algo, define.points, define.data) - } - - for(let i = 0; i < samples.length; i++){ - dataPoints.push(`${define.name},test=generic ${define.measurement}=${samples[i]} ${startMillis + (intervals.step * i)}\n`); - } - - await dataPoints.forEach(async point => { - await fs.appendFile(filePath, point, err => { - if(err){console.log('Error writing point ' + point + ' to file ' + filePath);} - }); - }); - -}; - -const genPoints = async (algo, count, data = null) => { - let samples = []; - switch(algo.toLowerCase()){ - case 'fibonacci': - samples = await genFibonacciValues(count); - break; - case 'hydro': - samples = await genHydroValues(count); - break; - case 'sine': - samples = await genSineValues(count); - break; - case 'log': - samples = await genLogisticValues(count); - break; - case 'life': - samples = await genLifeValues(count); - break; - case 'dico': - samples = await genDicoValues(count,data); - break; - default: - throw `Unhandled mode ${algo}`; - } - return samples; -}; - -// 'start' should have time format e.g. -2h, 30m, 1d -const getIntervalMillis = async(count, start) => { - let time = start.slice(0, -1); - let fullInterval = 0; - let pointInterval; - switch(start[start.length - 1]){ - case 'd': //days - fullInterval = Math.abs(parseInt(time)) * 24 * 60000 * 60; - break; - case 'h': //hours - fullInterval = Math.abs(parseInt(time)) * 60000 * 60; - break; - case 'm': //minutes - fullInterval = Math.abs(parseInt(time)) * 60000; - break; - case 's': //seconds - fullInterval = Math.abs(parseInt(time)) * 1000; - break; - default: - throw new `unhandle time unit ${start}`; - } - - pointInterval = fullInterval / count; - return {full: fullInterval, step: pointInterval}; -}; - -const genFibonacciValues = async (count) => { - let result = []; - for(let i = 0; i < count; i++){ - if(i === 0){ - result.push(1); - }else if(i === 1){ - result.push(2); - }else{ - result.push(result[i-1] + result[i-2]); - } - } - return result; -}; - -const genHydroValues = async(count) => { - let current = Math.floor(Math.random() * 400) + 100; - let result = []; - let trend = (Math.floor(Math.random() * 10) - 5); - - for(let i = 0; i < count; i++){ - current += (Math.floor(Math.random() * 10) + trend); - result.push(current/100.0); - if(current < trend){ //negative trend could lead to neg value so set new trend - trend = Math.floor(Math.random() * 5); - }else if(current > (500 - trend)){ // pushing ceiling set neg trend - trend = Math.floor(Math.random() * -5); - } - } - return result; -}; - -const genSineValues = async(count) => { - let result = []; - for(let i = 0; i < count; i++){ - result.push(Math.sin(i) * 1000); - } - return result; -}; - -const genLogisticValues = async(count) => { - let result = []; - let reset = ((Math.random() * 5) * 10) + 10; - let resetReset = Math.round(reset); - for(let i = 0; i < count; i++){ - result.push(((1/(1 + ((1/2.71828)**(i % reset)))) * 100) + ((Math.random() * 10) - 5)); // + ((Math.random() * 10) - 5)); - if(i === resetReset){ - reset = ((Math.random() * 5) * 10) + 10; - resetReset += Math.round(reset); - } - } - return result; -}; - -const genLifeValues = async(count) => { - let result = []; - let carryCap = ((Math.random() * 9) * 100) + 100; - let growthRate = Math.random() + 1; - //console.log("DEBUG carryCap " + carryCap + " growthRate " + growthRate); - result.push(2.0); - for(let i = 1; i < count; i++){ - let accGrowth = growthRate + (0.10 - (Math.random() * 0.20)); - if(result[i-1] > carryCap){ //cull - let overshoot = result[i -1] - carryCap; - let cull = overshoot * 2; //((Math.random() * 2) + 1); - //console.log('DEBUG culling ' + cull + " cull percent " + cull/carryCap); - if(carryCap - cull < 2){ - result.push(2); //reseed - growthRate = growthRate * 0.95; - }else{ - result.push(result[i - 1] - cull); - } - let origCarryCap = carryCap; - carryCap -= (carryCap * (cull/carryCap * 0.1)); //overshoot degrades carrying capacity - if(carryCap < origCarryCap / 2){ - carryCap = origCarryCap/2; - } - }else if(result[i-1] < 2){ - result.push(2); - }else{ - result.push(result[i - 1] ** accGrowth); - } - } - return result; -}; - -const genDicoValues = async(count,data) => { - let result = []; - for(let i = 0; i < count; i++){ - result[i] = data[Math.floor(Math.random() * Math.floor(data.length))]; - } - return result; -}; - - -const readFileToBuffer = async function(filepath) { - return await fs.readFileSync(filepath, 'utf-8'); -}; - -const removeFileIfExists = async function(filepath){ - if(fs.existsSync(filepath)) { - fs.unlinkSync(filepath); - } -}; - -const removeDownloadFilesByRegex = async function(regex){ - let re = new RegExp(regex) - await fs.readdir(__config.download_dir, (err, files) => { - for(var i = 0; i < files.length; i++){ - var match = files[i].match(re); - if(match !== null){ - fs.unlinkSync(__config.download_dir + '/' +match[0]); - } - } - }); -}; - -const fileExists = async function(filePath){ - return fs.existsSync(__config.download_dir + '/' + filePath); -}; - -const dumpDownloadDir = async function(){ - console.log("DEBUG __config.download_dir: " + __config.download_dir ) - let files = fs.readdirSync(__config.download_dir); - for(var file of files){ - console.log(" " + file ); - } - console.log("DEBUG __config.download_dir/..: " + __config.download_dir ) - files = fs.readdirSync(__config.download_dir + '/..'); - for(var file of files){ - console.log(" " + file ); - } - - -} - -const verifyDownloadFileMatchingRegexFilesExist = async function(regex, callback){ - let re = new RegExp(regex); - let files = fs.readdirSync(__config.download_dir); - - console.log("DEBUG files to be matched: \n" + files); - - for(var i = 0; i < files.length; i++){ - var match = files[i].match(re); - if(match !== null){ - return true; - } - } - - return false; -}; - -const waitForFileToExist = async function(filePath, timeout = 60000){ - let sleepTime = 3000; - let totalSleep = 0; - while (totalSleep < timeout){ - if(fs.existsSync(__config.download_dir + '/' + filePath)){ - return true; - } - await __wdriver.sleep(sleepTime); - totalSleep += sleepTime; - } - - - throw `Timed out ${timeout}ms waiting for file ${__config.download_dir}/${filePath}`; - -}; - -const getNthFileFromRegex = async function(fileregex, index){ - let re = await new RegExp(fileregex); - let files = fs.readdirSync('.'); - let matchFiles = []; - - for(var i = 0; i < files.length; i++){ - var match = files[i].match(re); - if(match !== null){ - matchFiles.push(files[i]); - } - } - - return matchFiles[index - 1]; -}; - -const readCSV = async function(content){ - return await csvParseSync(content, { columns: true, skip_empty_lines: true, comment: "#"}); -}; - - -function sleep(ms){ - return new Promise(resolve => setTimeout(() => resolve(), ms)); -} - -const dataGenProcess = async function(def = {pulse: 333, model: 'count10'}){ - - let total = 100; - let point = -1; - let val; - while(point++ < total && !__killLiveDataGen) { - let current = (new Date()).getTime(); - switch(def.model){ - case 'count10': - val = point%10; - break; - default: - val = `"model_${def.model}_undefined"`; - break; - } - //console.log("PULSE " + val); - await writeData(__defaultUser.username, [ - `test,gen=gen val=${val} ${current * mil2Nano}` - ]); - __liveDataGenRunning = true; - await sleep(def.pulse) - } - - console.warn(`Live data generation process stopped ${(new Date()).toISOString()}`); - __liveDataGenRunning = false; -}; - -const startLiveDataGen = async function(def){ - if(!__liveDataGenRunning) { - console.log(`Starting live generator with ${JSON.stringify(def)} ${(new Date()).toISOString()}`); - __killLiveDataGen = false; - await dataGenProcess(JSON.parse(def)); - }else{ - console.log(`Live Data Generator already running ${(new Date()).toISOString()}`); - } -}; - -const stopLiveDataGen = function(){ - __killLiveDataGen = true; -}; - -module.exports = { flush, - config, - defaultUser, - setupUser, - putUser, - getUser, - signInAxios, - endSession, - writeData, - createDashboard, - createVariable, - dumpDownloadDir, - getDashboards, - query, - createBucket, - parseQueryResults, - createLabel, - createAlertCheckFromFile, - genLineProtocolFile, - getIntervalMillis, - getDocTemplates, - getNthFileFromRegex, - genFibonacciValues, - writeLineProtocolData, - readFileToBuffer, - readCSV, - createTemplateFromFile, - getAuthorizations, - removeConfInDocker, - removeFileIfExists, - removeDownloadFilesByRegex, - setupNewUser, - startLiveDataGen, - stopLiveDataGen, - fileExists, - verifyDownloadFileMatchingRegexFilesExist, - waitForFileToExist -}; - -//flush() diff --git a/e2e/src/utils/junitReport.js b/e2e/src/utils/junitReport.js deleted file mode 100755 index 0ea042f825..0000000000 --- a/e2e/src/utils/junitReport.js +++ /dev/null @@ -1,9 +0,0 @@ -#!/usr/bin/env node -const cucumberJunitConvert = require('cucumber-junit-convert'); - -const options = { - inputJsonFile: 'report/cucumber_report.json', - outputXmlFile: 'report/cucumber_junit.xml' -}; - -cucumberJunitConvert.convert(options); diff --git a/e2e/src/utils/performanceUtils.js b/e2e/src/utils/performanceUtils.js deleted file mode 100644 index 681d7d7262..0000000000 --- a/e2e/src/utils/performanceUtils.js +++ /dev/null @@ -1,149 +0,0 @@ -const assert = require('chai').assert; -const fs = require('fs'); - -let performanceLog = []; -let performanceRecFile = './report/performance.csv'; - -//performance record -//let rec = { name: string, state: string, expected: long, start: long, stop: long, duration: long, message: string } - -const execTimed = async ( func, maxDelay, failMsg, successMsg) => { - - if(typeof(maxDelay) !== 'number'){ - throw `maxDelay must be of type number. Got ${typeof(maxDelay)}` - } - - let start = new Date(); - let startl = start.getTime(); - await func(); - let finish = new Date(); - let finishl = finish.getTime(); - try{ - assert.isBelow(finishl-startl, maxDelay, failMsg); - performanceLog.push({name: `${__currentFeature}: ${__currentScenario}`, - state: 'pass', - maxTime: maxDelay, - duration: finishl - startl, - delta: maxDelay - (finishl - startl), - start: start.toISOString(), - message: (typeof(successMsg) === 'undefined')? 'success' : successMsg, - }); - }catch(err){ - performanceLog.push({name: `${__currentFeature}: ${__currentScenario}`, - state: 'fail', - maxTime: maxDelay, - duration: finish - start, - delta: maxDelay - (finish - start), - start: start.toISOString(), - message: (typeof(failMsg) === 'undefined') ? 'failure' : failMsg, - }); - throw err; - } -}; - -const writePerformanceLog = async () => { - if(performanceLog.length < 1){ - return; - } - console.log('\nPerformance'); - let header = []; - for(let prop in performanceLog[0]){ - if(performanceLog[0].hasOwnProperty(prop)){ - header.push(`${prop}`); - } - } - - let fieldSizes = {}; - for(let field of header){ - fieldSizes[field] = field.length; - } - - //console.log(JSON.stringify(fieldSizes)); - - for(let log of performanceLog){ - for(let field of header){ - if(log[field].toString().length > fieldSizes[field]){ - fieldSizes[field] = log[field].toString().length; - } - } - } - - for(let field of header){ - fieldSizes[field] += 2; - } - - let headerString = ''; - - for(let f of header){ - headerString += f.padEnd(fieldSizes[f]) + "| "; - } - - console.log(headerString); - - //add divider - console.log('-'.padEnd(Object.values(fieldSizes).reduce((a,b) => a+b+2), '-')); - let successCt = 0; - let failCt = 0; - for(let log of performanceLog){ - let row = ''; - for(let f of header){ - row += log[f].toString().padEnd(fieldSizes[f]) + "| "; - } - - if(log.state === 'fail'){ - console.log('\x1b[31m%s\x1b[0m', row); - failCt++; - }else{ - console.log('\x1b[32m%s\x1b[0m', row); - successCt++; - } - } - //add divider - console.log('-'.padEnd(Object.values(fieldSizes).reduce((a,b) => a+b+2), '-')); - console.log('\x1b[96m%s\x1b[0m', 'Performance scenarios'); - console.log(`total: ${performanceLog.length}`); - if(successCt > 0){ - console.log('\x1b[32m%s\x1b[0m', `success: ${successCt}` ); - } - if(failCt > 0){ - console.log('\x1b[31m%s\x1b[0m', `fail: ${failCt}` ); - } - console.log() -}; - -const writePerformanceReport = async (filename = performanceRecFile) => { - - let header = []; - - for(let prop in performanceLog[0]){ - if(performanceLog[0].hasOwnProperty(prop)){ - header.push(`${prop}`); - } - } - - //write header if report does not yet exist - if(!fs.existsSync(filename)){ - - for(let f of header){ - await fs.appendFileSync(filename, `${f},`) - } - - await fs.appendFileSync(filename,'\n'); - - } - - - for(let log of performanceLog) { - for(let f of header){ - await fs.appendFileSync(filename, `${log[f].toString()},`); - } - await fs.appendFileSync(filename, '\n'); - } -}; - -module.exports = { - execTimed, - performanceLog, - writePerformanceLog, - writePerformanceReport -};