-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
* Revert "remove records with grouping (#26)" This reverts commit 9efdbaf. * Query grouping dashboard changes and extensive tests * Fix tests and linting * Address review comments * Address review comments and update tests * Update cypress tests, hashcode to id, refactoring * Lint --------- Signed-off-by: Siddhant Deshmukh <[email protected]> Co-authored-by: Siddhant Deshmukh <[email protected]>
- Loading branch information
Showing
26 changed files
with
1,879 additions
and
256 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,154 +1,154 @@ | ||
name: Cypress e2e integration tests workflow | ||
on: | ||
pull_request: | ||
branches: | ||
- "*" | ||
push: | ||
branches: | ||
- "*" | ||
env: | ||
OPENSEARCH_DASHBOARDS_VERSION: '2.x' | ||
QUERY_INSIGHTS_BRANCH: '2.x' | ||
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 & | ||
timeout 300 bash -c 'while [[ "$(curl -s -o /dev/null -w ''%{http_code}'' localhost:9200)" != "200" ]]; do sleep 5; done' | ||
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: '2.x' | ||
QUERY_INSIGHTS_BRANCH: '2.x' | ||
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 & | ||
timeout 300 bash -c 'while [[ "$(curl -s -o /dev/null -w ''%{http_code}'' localhost:9200)" != "200" ]]; do sleep 5; done' | ||
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.