# Copyright 2021 Collate # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # http://www.apache.org/licenses/LICENSE-2.0 # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. name: py-tests-postgres on: workflow_dispatch: pull_request_target: types: [labeled, opened, synchronize, reopened, ready_for_review] permissions: contents: read concurrency: group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} cancel-in-progress: true jobs: # Detect whether relevant paths changed. When no Python/service/schema files # are modified the downstream jobs are skipped via their `if` condition. # A job skipped by `if` reports as "Success", so required checks still pass. changes: name: Detect Changes runs-on: ubuntu-latest if: ${{ !github.event.pull_request.draft }} outputs: python: ${{ github.event_name == 'workflow_dispatch' && 'true' || steps.filter.outputs.python }} steps: - uses: dorny/paths-filter@v3 id: filter if: ${{ github.event_name != 'workflow_dispatch' }} with: filters: | python: - 'ingestion/**' - 'openmetadata-service/**' - 'openmetadata-spec/src/main/resources/json/schema/**' - 'pom.xml' - 'Makefile' py-integration-tests: name: "Integration Tests (${{ matrix.shard.name }}, ${{ matrix.py-version }})" needs: changes if: ${{ needs.changes.outputs.python == 'true' }} timeout-minutes: 180 runs-on: ubuntu-latest strategy: fail-fast: false matrix: py-version: ["3.10", "3.11"] # , "3.12"] shard: - name: "shard-1" nox-args: >- tests/integration/ometa tests/integration/postgres tests/integration/mysql tests/integration/profiler tests/integration/data_quality - name: "shard-2" nox-args: >- --ignore=tests/integration/ometa --ignore=tests/integration/postgres --ignore=tests/integration/mysql --ignore=tests/integration/profiler --ignore=tests/integration/data_quality steps: - name: Free Disk Space (Ubuntu) uses: jlumbroso/free-disk-space@main with: tool-cache: false android: true dotnet: true haskell: true large-packages: false swap-storage: true docker-images: false - name: Wait for the labeler uses: lewagon/wait-on-check-action@v1.3.4 if: ${{ github.event_name == 'pull_request_target' }} with: ref: ${{ github.event.pull_request.head.sha }} check-name: Team Label repo-token: ${{ secrets.GITHUB_TOKEN }} wait-interval: 90 - name: Verify PR labels uses: jesusvasquez333/verify-pr-label-action@v1.4.0 if: ${{ github.event_name == 'pull_request_target' }} with: github-token: "${{ secrets.GITHUB_TOKEN }}" valid-labels: "safe to test" pull-request-number: "${{ github.event.pull_request.number }}" disable-reviews: true # To not auto approve changes - name: Checkout uses: actions/checkout@v4 with: ref: ${{ github.event.pull_request.head.sha }} - name: Setup Openmetadata Test Environment uses: ./.github/actions/setup-openmetadata-test-environment with: python-version: ${{ matrix.py-version}} args: "-m no-ui -d postgresql" ingestion_dependency: "mysql,elasticsearch,sample-data" - name: Run Integration Tests run: | source env/bin/activate cd ingestion nox --no-venv -s integration-tests -- --standalone --durations=5 ${{ matrix.shard.nox-args }} env: TESTCONTAINERS_RYUK_DISABLED: true shell: bash - name: Clean Up run: | cd ./docker/development docker compose down --remove-orphans sudo rm -rf ${PWD}/docker-volume # Single required-check gate for branch protection. # Skipped (= "Success") when all test jobs pass or are legitimately skipped. # Runs and exits 1 only when a test job fails or is cancelled. # Set "py-tests-postgres / py-tests-status" as the sole required check for this workflow. py-tests-status: name: py-tests-status needs: [changes, py-integration-tests] if: ${{ failure() || cancelled() }} runs-on: ubuntu-latest steps: - run: exit 1