-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Query grouping dashboard changes and extensive tests (#33)
* Revert "remove records with grouping (#26)" This reverts commit 9efdbaf. Signed-off-by: Siddhant Deshmukh <[email protected]> * Query grouping dashboard changes and extensive tests Signed-off-by: Siddhant Deshmukh <[email protected]> * Fix tests and linting Signed-off-by: Siddhant Deshmukh <[email protected]> * Address review comments Signed-off-by: Siddhant Deshmukh <[email protected]> * Address review comments and update tests Signed-off-by: Siddhant Deshmukh <[email protected]> * Update cypress tests, hashcode to id, refactoring Signed-off-by: Siddhant Deshmukh <[email protected]> * Lint Signed-off-by: Siddhant Deshmukh <[email protected]> --------- Signed-off-by: Siddhant Deshmukh <[email protected]>
- Loading branch information
Showing
26 changed files
with
1,880 additions
and
257 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,155 +1,155 @@ | ||
name: Cypress e2e integration tests workflow | ||
on: | ||
pull_request: | ||
branches: | ||
- "*" | ||
push: | ||
branches: | ||
- "*" | ||
env: | ||
OPENSEARCH_DASHBOARDS_VERSION: 'main' | ||
OPENSEARCH_VERSION: '3.0.0-SNAPSHOT' | ||
QUERY_INSIGHTS_BRANCH: 'main' | ||
GRADLE_VERSION: '7.6.1' | ||
jobs: | ||
tests: | ||
name: Run Cypress E2E tests | ||
strategy: | ||
matrix: | ||
os: [ubuntu-latest, windows-latest] | ||
include: | ||
- os: windows-latest | ||
cypress_cache_folder: ~/AppData/Local/Cypress/Cache | ||
- os: ubuntu-latest | ||
cypress_cache_folder: ~/.cache/Cypress | ||
runs-on: ${{ matrix.os }} | ||
env: | ||
# prevents extra Cypress installation progress messages | ||
CI: 1 | ||
# avoid warnings like "tput: No value for $TERM and no -T specified" | ||
TERM: xterm | ||
steps: | ||
- name: Set up JDK | ||
uses: actions/setup-java@v1 | ||
with: | ||
java-version: 21 | ||
|
||
- name: Enable longer filenames | ||
if: ${{ matrix.os == 'windows-latest' }} | ||
run: git config --system core.longpaths true | ||
|
||
- name: Checkout Query Insights | ||
uses: actions/checkout@v2 | ||
with: | ||
path: query-insights | ||
repository: opensearch-project/query-insights | ||
ref: ${{ env.QUERY_INSIGHTS_BRANCH }} | ||
|
||
- name: Set up Gradle | ||
uses: gradle/gradle-build-action@v2 | ||
with: | ||
gradle-version: ${{ env.GRADLE_VERSION }} | ||
|
||
- name: Run OpenSearch with Query Insights plugin | ||
run: | | ||
cd query-insights | ||
./gradlew run -Dopensearch.version=${{ env.OPENSEARCH_VERSION }} & | ||
sleep 300 | ||
shell: bash | ||
|
||
- name: Checkout OpenSearch-Dashboards | ||
uses: actions/checkout@v2 | ||
with: | ||
repository: opensearch-project/OpenSearch-Dashboards | ||
path: OpenSearch-Dashboards | ||
ref: ${{ env.OPENSEARCH_DASHBOARDS_VERSION }} | ||
|
||
- name: Checkout Query Insights Dashboards plugin | ||
uses: actions/checkout@v2 | ||
with: | ||
path: OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
|
||
- name: Setup Node | ||
uses: actions/setup-node@v3 | ||
with: | ||
node-version-file: './OpenSearch-Dashboards/.nvmrc' | ||
registry-url: 'https://registry.npmjs.org' | ||
|
||
- name: Install Yarn | ||
# Need to use bash to avoid having a windows/linux specific step | ||
shell: bash | ||
run: | | ||
YARN_VERSION=$(node -p "require('./OpenSearch-Dashboards/package.json').engines.yarn") | ||
echo "Installing yarn@$YARN_VERSION" | ||
npm i -g yarn@$YARN_VERSION | ||
- run: node -v | ||
- run: yarn -v | ||
|
||
- name: Bootstrap plugin/OpenSearch-Dashboards | ||
run: | | ||
cd OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
yarn osd bootstrap --single-version=loose | ||
- name: Run OpenSearch-Dashboards server | ||
run: | | ||
cd OpenSearch-Dashboards | ||
yarn start --no-base-path --no-watch --server.host="0.0.0.0" & | ||
shell: bash | ||
|
||
# Window is slow so wait longer | ||
- name: Sleep until OSD server starts - windows | ||
if: ${{ matrix.os == 'windows-latest' }} | ||
run: Start-Sleep -s 600 | ||
shell: powershell | ||
|
||
- name: Sleep until OSD server starts - non-windows | ||
if: ${{ matrix.os != 'windows-latest' }} | ||
run: sleep 500 | ||
shell: bash | ||
|
||
- name: Install Cypress | ||
run: | | ||
cd OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
# This will install Cypress in case the binary is missing which can happen on Windows and Mac | ||
# If the binary exists, this will exit quickly so it should not be an expensive operation | ||
npx cypress install | ||
shell: bash | ||
|
||
- name: Get Cypress version | ||
id: cypress_version | ||
run: | | ||
cd OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
echo "::set-output name=cypress_version::$(cat ./package.json | jq '.dependencies.cypress' | tr -d '"')" | ||
- name: Cache Cypress | ||
id: cache-cypress | ||
uses: actions/cache@v2 | ||
with: | ||
path: ${{ matrix.cypress_cache_folder }} | ||
key: cypress-cache-v2-${{ matrix.os }}-${{ hashFiles('OpenSearch-Dashboards/plugins/query-insights-dashboards/package.json') }} | ||
|
||
# for now just chrome, use matrix to do all browsers later | ||
- name: Cypress tests | ||
uses: cypress-io/github-action@v5 | ||
with: | ||
working-directory: OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
command: yarn run cypress run | ||
wait-on: 'http://localhost:5601' | ||
wait-on-timeout: 600 | ||
browser: chrome | ||
env: | ||
CYPRESS_CACHE_FOLDER: ${{ matrix.cypress_cache_folder }} | ||
|
||
# Screenshots are only captured on failure, will change this once we do visual regression tests | ||
- uses: actions/upload-artifact@v4 | ||
if: failure() | ||
with: | ||
name: cypress-screenshots-${{ matrix.os }} | ||
path: OpenSearch-Dashboards/plugins/query-insights-dashboards/cypress/screenshots | ||
|
||
# Test run video was always captured, so this action uses "always()" condition | ||
- uses: actions/upload-artifact@v4 | ||
if: always() | ||
with: | ||
name: cypress-videos-${{ matrix.os }} | ||
path: OpenSearch-Dashboards/plugins/query-insights-dashboards/cypress/videos | ||
name: Cypress e2e integration tests workflow | ||
on: | ||
pull_request: | ||
branches: | ||
- "*" | ||
push: | ||
branches: | ||
- "*" | ||
env: | ||
OPENSEARCH_DASHBOARDS_VERSION: 'main' | ||
OPENSEARCH_VERSION: '3.0.0-SNAPSHOT' | ||
QUERY_INSIGHTS_BRANCH: 'main' | ||
GRADLE_VERSION: '7.6.1' | ||
jobs: | ||
tests: | ||
name: Run Cypress E2E tests | ||
strategy: | ||
matrix: | ||
os: [ubuntu-latest, windows-latest] | ||
include: | ||
- os: windows-latest | ||
cypress_cache_folder: ~/AppData/Local/Cypress/Cache | ||
- os: ubuntu-latest | ||
cypress_cache_folder: ~/.cache/Cypress | ||
runs-on: ${{ matrix.os }} | ||
env: | ||
# prevents extra Cypress installation progress messages | ||
CI: 1 | ||
# avoid warnings like "tput: No value for $TERM and no -T specified" | ||
TERM: xterm | ||
steps: | ||
- name: Set up JDK | ||
uses: actions/setup-java@v1 | ||
with: | ||
java-version: 21 | ||
|
||
- name: Enable longer filenames | ||
if: ${{ matrix.os == 'windows-latest' }} | ||
run: git config --system core.longpaths true | ||
|
||
- name: Checkout Query Insights | ||
uses: actions/checkout@v2 | ||
with: | ||
path: query-insights | ||
repository: opensearch-project/query-insights | ||
ref: ${{ env.QUERY_INSIGHTS_BRANCH }} | ||
|
||
- name: Set up Gradle | ||
uses: gradle/gradle-build-action@v2 | ||
with: | ||
gradle-version: ${{ env.GRADLE_VERSION }} | ||
|
||
- name: Run OpenSearch with Query Insights plugin | ||
run: | | ||
cd query-insights | ||
./gradlew run -Dopensearch.version=${{ env.OPENSEARCH_VERSION }} & | ||
sleep 300 | ||
shell: bash | ||
|
||
- name: Checkout OpenSearch-Dashboards | ||
uses: actions/checkout@v2 | ||
with: | ||
repository: opensearch-project/OpenSearch-Dashboards | ||
path: OpenSearch-Dashboards | ||
ref: ${{ env.OPENSEARCH_DASHBOARDS_VERSION }} | ||
|
||
- name: Checkout Query Insights Dashboards plugin | ||
uses: actions/checkout@v2 | ||
with: | ||
path: OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
|
||
- name: Setup Node | ||
uses: actions/setup-node@v3 | ||
with: | ||
node-version-file: './OpenSearch-Dashboards/.nvmrc' | ||
registry-url: 'https://registry.npmjs.org' | ||
|
||
- name: Install Yarn | ||
# Need to use bash to avoid having a windows/linux specific step | ||
shell: bash | ||
run: | | ||
YARN_VERSION=$(node -p "require('./OpenSearch-Dashboards/package.json').engines.yarn") | ||
echo "Installing yarn@$YARN_VERSION" | ||
npm i -g yarn@$YARN_VERSION | ||
- run: node -v | ||
- run: yarn -v | ||
|
||
- name: Bootstrap plugin/OpenSearch-Dashboards | ||
run: | | ||
cd OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
yarn osd bootstrap --single-version=loose | ||
- name: Run OpenSearch-Dashboards server | ||
run: | | ||
cd OpenSearch-Dashboards | ||
yarn start --no-base-path --no-watch --server.host="0.0.0.0" & | ||
shell: bash | ||
|
||
# Window is slow so wait longer | ||
- name: Sleep until OSD server starts - windows | ||
if: ${{ matrix.os == 'windows-latest' }} | ||
run: Start-Sleep -s 600 | ||
shell: powershell | ||
|
||
- name: Sleep until OSD server starts - non-windows | ||
if: ${{ matrix.os != 'windows-latest' }} | ||
run: sleep 500 | ||
shell: bash | ||
|
||
- name: Install Cypress | ||
run: | | ||
cd OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
# This will install Cypress in case the binary is missing which can happen on Windows and Mac | ||
# If the binary exists, this will exit quickly so it should not be an expensive operation | ||
npx cypress install | ||
shell: bash | ||
|
||
- name: Get Cypress version | ||
id: cypress_version | ||
run: | | ||
cd OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
echo "::set-output name=cypress_version::$(cat ./package.json | jq '.dependencies.cypress' | tr -d '"')" | ||
- name: Cache Cypress | ||
id: cache-cypress | ||
uses: actions/cache@v2 | ||
with: | ||
path: ${{ matrix.cypress_cache_folder }} | ||
key: cypress-cache-v2-${{ matrix.os }}-${{ hashFiles('OpenSearch-Dashboards/plugins/query-insights-dashboards/package.json') }} | ||
|
||
# for now just chrome, use matrix to do all browsers later | ||
- name: Cypress tests | ||
uses: cypress-io/github-action@v5 | ||
with: | ||
working-directory: OpenSearch-Dashboards/plugins/query-insights-dashboards | ||
command: yarn run cypress run | ||
wait-on: 'http://localhost:5601' | ||
wait-on-timeout: 600 | ||
browser: chrome | ||
env: | ||
CYPRESS_CACHE_FOLDER: ${{ matrix.cypress_cache_folder }} | ||
|
||
# Screenshots are only captured on failure, will change this once we do visual regression tests | ||
- uses: actions/upload-artifact@v4 | ||
if: failure() | ||
with: | ||
name: cypress-screenshots-${{ matrix.os }} | ||
path: OpenSearch-Dashboards/plugins/query-insights-dashboards/cypress/screenshots | ||
|
||
# Test run video was always captured, so this action uses "always()" condition | ||
- uses: actions/upload-artifact@v4 | ||
if: always() | ||
with: | ||
name: cypress-videos-${{ matrix.os }} | ||
path: OpenSearch-Dashboards/plugins/query-insights-dashboards/cypress/videos |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.