Create and Delete MaaSModelRefs #747
This file contains hidden or 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
| name: Test | |
| on: [push, pull_request] | |
| # Concurrency control: Only run latest tests for each PR/branch | |
| # Cancel in-progress runs when new commits are pushed | |
| concurrency: | |
| group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} | |
| cancel-in-progress: true | |
| env: | |
| NODE_VERSION: 22.x | |
| DO_NOT_TRACK: 1 | |
| NODE_MODULES_CACHE_VERSION: 1 | |
| jobs: | |
| Setup: | |
| runs-on: ubuntu-latest | |
| outputs: | |
| modules-cache-key: ${{ steps.key.outputs.modules-cache-key }} | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Validate all package-lock.json files | |
| run: ./scripts/check-package-lock.sh --all | |
| - name: Generate modules cache key | |
| id: key | |
| run: | | |
| echo "modules-cache-key=${{ runner.os }}-${{ env.NODE_VERSION }}-modules-${{ env.NODE_MODULES_CACHE_VERSION }}-${{ hashFiles('**/package-lock.json') }}" >> $GITHUB_OUTPUT | |
| - name: Node.js modules cache | |
| uses: actions/cache@v4 | |
| id: modules-cache | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ steps.key.outputs.modules-cache-key }} | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Install dependencies | |
| run: npm install | |
| - name: Validate module federation ports | |
| run: npm run validate:ports | |
| - name: Check for uncommitted changes | |
| run: git diff --exit-code | |
| Type-Check: | |
| needs: Setup | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Restore cache | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ needs.Setup.outputs.modules-cache-key }} | |
| - name: Cache turbo | |
| uses: actions/cache@v4 | |
| with: | |
| path: | | |
| **/.turbo | |
| key: ${{ runner.os }}-${{ env.NODE_VERSION }}-turbo-${{ github.sha }}-type-check | |
| restore-keys: | | |
| ${{ runner.os }}-${{ env.NODE_VERSION }}-turbo- | |
| - name: Run type checks | |
| run: npm run type-check | |
| Lint: | |
| needs: Setup | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Restore cache | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ needs.Setup.outputs.modules-cache-key }} | |
| - name: Cache turbo | |
| uses: actions/cache@v4 | |
| with: | |
| path: | | |
| **/.turbo | |
| key: ${{ runner.os }}-${{ env.NODE_VERSION }}-turbo-${{ github.sha }}-lint | |
| restore-keys: | | |
| ${{ runner.os }}-${{ env.NODE_VERSION }}-turbo- | |
| - name: Run linting and formatting checks | |
| run: NODE_OPTIONS="--max-old-space-size=8192" npm run lint | |
| Unit-Tests: | |
| needs: [Setup, Lint, Type-Check] | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Restore cache | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ needs.Setup.outputs.modules-cache-key }} | |
| - name: Cache turbo | |
| uses: actions/cache@v4 | |
| with: | |
| path: | | |
| **/.turbo | |
| key: ${{ runner.os }}-${{ env.NODE_VERSION }}-turbo-${{ github.sha }}-unit-tests | |
| restore-keys: | | |
| ${{ runner.os }}-${{ env.NODE_VERSION }}-turbo- | |
| - name: Unit tests with coverage | |
| run: | | |
| npm run test-unit-coverage | |
| - name: Upload unit test coverage | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: unit-coverage | |
| path: ./jest-coverage | |
| if-no-files-found: error | |
| Get-Test-Groups: | |
| needs: Setup | |
| runs-on: ubuntu-latest | |
| outputs: | |
| test-groups: ${{ steps.set-groups.outputs.test-groups }} | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Restore cache | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ needs.Setup.outputs.modules-cache-key }} | |
| - id: set-groups | |
| shell: bash | |
| run: | | |
| set -x # Enable debug mode to see each command | |
| TEST_GROUPS="[]" | |
| # 1. Discover central cypress test groups | |
| if [ -d "packages/cypress/cypress/tests/mocked" ]; then | |
| echo "Found mocked tests directory" | |
| # Get directories and create JSON objects with name and spec | |
| # spec includes "cypress/" prefix so all specs are relative to packages/ | |
| CENTRAL_GROUPS=$(cd packages/cypress/cypress/tests/mocked && \ | |
| find . -name "*.cy.*" -printf "%h\n" | sed 's|^\./||' | sort -u | \ | |
| jq -R '{"name": ., "spec": ("cypress/cypress/tests/mocked/" + . + "/*")}' | jq -c -s .) | |
| TEST_GROUPS=$(echo "$TEST_GROUPS" | jq -c --argjson central "$CENTRAL_GROUPS" '. + $central') | |
| echo "Central test groups: $CENTRAL_GROUPS" | |
| fi | |
| # 2. Discover package-based cypress tests using npm query | |
| echo "Discovering package-based cypress tests..." | |
| # spec includes package name so all specs are relative to packages/ | |
| PKG_GROUPS=$(npm query '.workspace' --json | jq -c ' | |
| [.[] | select(.cypress.mocked != null and .name != "@odh-dashboard/cypress") | | |
| { | |
| "name": ("pkg-" + (.name | split("/") | .[-1])), | |
| "spec": ((.name | split("/") | .[-1]) + "/" + .cypress.mocked) | |
| } | |
| ] | |
| ') | |
| if [ "$PKG_GROUPS" != "[]" ]; then | |
| # Verify each package has actual test files before adding | |
| for row in $(echo "$PKG_GROUPS" | jq -c '.[]'); do | |
| PKG_NAME=$(echo "$row" | jq -r '.name' | sed 's/^pkg-//') | |
| if find "packages/$PKG_NAME" -name "*.cy.ts" 2>/dev/null | grep -q .; then | |
| TEST_GROUPS=$(echo "$TEST_GROUPS" | jq -c --argjson row "$row" '. + [$row]') | |
| echo "Added package test group: $row" | |
| fi | |
| done | |
| fi | |
| # Fallback if no groups found | |
| if [ "$TEST_GROUPS" == "[]" ]; then | |
| echo "No test groups found, using default" | |
| TEST_GROUPS='[{"name": "default", "spec": "cypress/cypress/tests/mocked/**/*.cy.ts"}]' | |
| fi | |
| # Output in the correct format for GitHub Actions | |
| echo "test-groups=$TEST_GROUPS" >> "$GITHUB_OUTPUT" | |
| echo "Generated test groups:" | |
| echo "$TEST_GROUPS" | jq . | |
| Contract-Tests: | |
| needs: [Setup, Lint, Type-Check] | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Setup Go | |
| uses: actions/setup-go@v5 | |
| with: | |
| go-version: '1.25' | |
| cache-dependency-path: | | |
| packages/model-registry/upstream/bff/go.sum | |
| packages/gen-ai/bff/go.sum | |
| packages/mlflow/bff/go.sum | |
| - name: Restore cache | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ needs.Setup.outputs.modules-cache-key }} | |
| - name: Run contract tests | |
| run: | | |
| export GITHUB_RUN_ID="$GITHUB_RUN_ID" | |
| export CI="true" | |
| npm run test:contract | |
| env: | |
| GITHUB_RUN_ID: ${{ github.run_id }} | |
| CI: true | |
| - name: Upload contract test results | |
| if: always() | |
| run: | | |
| # Find and upload the most recent contract test results | |
| LATEST_DIR=$(find packages/*/contract-tests/contract-test-results -name "ci-*" -type d 2>/dev/null | head -1) | |
| if [ -n "$LATEST_DIR" ] && [ -d "$LATEST_DIR" ]; then | |
| echo "Uploading from: $LATEST_DIR" && echo "results-dir=$LATEST_DIR" >> $GITHUB_OUTPUT | |
| else | |
| echo "No results found" && echo "results-dir=" >> $GITHUB_OUTPUT | |
| fi | |
| id: upload-results | |
| - name: Upload artifacts | |
| uses: actions/upload-artifact@v4 | |
| if: steps.upload-results.outputs.results-dir != '' | |
| with: | |
| name: contract-test-results | |
| path: ${{ steps.upload-results.outputs.results-dir }} | |
| Cypress-Setup: | |
| needs: [Setup] | |
| runs-on: ubuntu-latest | |
| outputs: | |
| cypress-cache-key: ${{ steps.key.outputs.cypress-cache-key }} | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Generate cypress cache key | |
| id: key | |
| run: | | |
| echo "cypress-cache-key=${{ runner.os }}-${{ env.NODE_VERSION }}-cypress-build-${{ github.sha }}" >> $GITHUB_OUTPUT | |
| - name: Cypress build cache | |
| uses: actions/cache@v4 | |
| id: cypress-build-cache | |
| with: | |
| lookup-only: true | |
| path: | | |
| **/public-cypress | |
| key: ${{ steps.key.outputs.cypress-cache-key }} | |
| - name: Restore cache | |
| if: steps.cypress-build-cache.outputs.cache-hit != 'true' | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ needs.Setup.outputs.modules-cache-key }} | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| if: steps.cypress-build-cache.outputs.cache-hit != 'true' | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Build for cypress | |
| if: steps.cypress-build-cache.outputs.cache-hit != 'true' | |
| run: npm run cypress:server:build:coverage -- --concurrency=4 | |
| Cypress-Mock-Tests: | |
| needs: [Setup, Lint, Type-Check, Cypress-Setup, Get-Test-Groups] | |
| runs-on: ubuntu-latest | |
| strategy: | |
| fail-fast: false | |
| matrix: | |
| test-group: ${{ fromJson(needs.Get-Test-Groups.outputs.test-groups) }} | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Restore cache | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| ~/.cache/Cypress | |
| **/node_modules | |
| key: ${{ needs.Setup.outputs.modules-cache-key }} | |
| - name: Restore Cypress build cache | |
| uses: actions/cache/restore@v4 | |
| with: | |
| path: | | |
| **/public-cypress | |
| key: ${{ needs.Cypress-Setup.outputs.cypress-cache-key }} | |
| - name: Run Cypress Mock tests | |
| run: | | |
| npm run test:cypress-ci:coverage:nobuild -- --spec "../packages/${{ matrix.test-group.spec }}" | |
| working-directory: ./frontend | |
| - name: Test group name | |
| if: ${{ always() }} | |
| run: echo "TEST_GROUP_NAME=$(echo '${{ matrix.test-group.name }}' | tr '/-' '_')" >> $GITHUB_ENV | |
| - name: Upload Cypress Mock results | |
| uses: actions/upload-artifact@v4 | |
| if: ${{ always() }} | |
| with: | |
| name: cypress-results-${{ env.TEST_GROUP_NAME }} | |
| path: ./packages/cypress/results/mocked | |
| - name: Upload Cypress coverage | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: cypress-coverage-${{ env.TEST_GROUP_NAME }} | |
| path: ./packages/cypress/coverage | |
| Combine-Results-and-Upload: | |
| needs: [Unit-Tests, Cypress-Mock-Tests] | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Setup Node.js ${{ env.NODE_VERSION }} | |
| uses: actions/setup-node@v4.3.0 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| - name: Download all artifacts | |
| uses: actions/download-artifact@v4 | |
| with: | |
| path: all-artifacts | |
| - name: Install dependencies | |
| run: npm install nyc --no-save | |
| - name: Combine coverage reports | |
| run: | | |
| mkdir -p ./coverage | |
| cp all-artifacts/unit-coverage/coverage-final.json ./coverage/unit-coverage-final.json || true | |
| find all-artifacts -name "cypress-coverage-*" -type d | while read dir; do | |
| group_name=$(basename "$dir") | |
| cp "$dir/coverage-final.json" "./coverage/${group_name}-coverage-final.json" || true | |
| done | |
| echo "Combined coverage files:" | |
| ls -R ./coverage | |
| - name: Merge coverage reports | |
| run: | | |
| npx nyc merge ./coverage ./coverage/merged-coverage.json | |
| echo "Cleaning up merged coverage file..." | |
| jq 'del(.[] | select(.statementMap == {}))' ./coverage/merged-coverage.json > ./coverage/cleaned-coverage.json | |
| mv ./coverage/cleaned-coverage.json ./coverage/merged-coverage.json | |
| - name: Generate coverage report | |
| run: | | |
| mkdir -p ./coverage/report | |
| npx nyc report --reporter=html --reporter=text-summary --temp-directory ./coverage -t ./coverage --report-dir ./coverage/report | |
| cp ./coverage/unit-coverage-final.json ./coverage/combined-coverage-final.json || true | |
| - name: Upload combined results | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: combined-coverage-results | |
| path: ./coverage/combined-coverage-final.json | |
| - name: Cleanup interim coverage files | |
| run: | | |
| rm -rf ./coverage/unit-coverage-final.json | |
| find ./coverage -name "*-coverage-final.json" -type f -delete | |
| - name: Upload coverage to Codecov | |
| uses: codecov/codecov-action@v4.6.0 | |
| with: | |
| token: ${{ secrets.CODECOV_TOKEN }} | |
| fail_ci_if_error: false | |
| name: frontend-and-backend | |
| file: ./coverage/merged-coverage.json | |
| disable_search: true | |
| directory: ./coverage | |
| verbose: true | |
| Tests: | |
| runs-on: ubuntu-latest | |
| needs: | |
| - Lint | |
| - Type-Check | |
| - Unit-Tests | |
| - Contract-Tests | |
| - Cypress-Mock-Tests | |
| - Combine-Results-and-Upload | |
| steps: | |
| - name: Verify all jobs succeeded | |
| run: echo "All required jobs have successfully completed for Node.js ${{ env.NODE_VERSION }}." |