# 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 on: push: branches: [main] paths: - ingestion/** pull_request_target: branches: [main] paths: - ingestion/** jobs: py-run-tests: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v2 with: ref: ${{ github.event.pull_request.head.sha }} - name: Set up JDK 11 uses: actions/setup-java@v2 with: java-version: '11' distribution: 'adopt' - name: Start Server and Ingest Sample Data run: ./docker/run_local_docker.sh timeout-minutes: 20 - name: Set up Python 3.9 uses: actions/setup-python@v2 with: python-version: 3.9 - name: Install Ubuntu dependencies run: | sudo apt-get install -y libsasl2-dev unixodbc-dev python3-venv - name: Install open-metadata dependencies run: | python3 -m venv env source env/bin/activate make install_test install_dev generate - name: Run Python Tests & record coverage run: | source env/bin/activate make coverage - name: Run PR Sonar env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} if: ${{ github.event_name == 'pull_request_target' }} run: | git fetch --no-tags https://github.com/open-metadata/OpenMetadata.git +refs/heads/main:refs/remotes/origin/main # Add PR analysis information echo "\nsonar.pullrequest.key=${{ github.event.pull_request.number }}" >> ingestion/sonar-project.properties echo "sonar.pullrequest.branch=${{ github.head_ref }}" >> ingestion/sonar-project.properties echo "sonar.pullrequest.base=main" >> ingestion/sonar-project.properties echo "sonar.pullrequest.github.repository=OpenMetadata" >> ingestion/sonar-project.properties echo "sonar.scm.revision=${{ github.event.pull_request.head.sha }}" >> ingestion/sonar-project.properties echo "sonar.pullrequest.provider=github" >> ingestion/sonar-project.properties # Validate new properties cat ingestion/sonar-project.properties make token=${{ secrets.INGESTION_SONAR_SECRET }} sonar_ingestion - name: Run Sonar env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} if: ${{ github.event_name == 'push' }} run: make token=${{ secrets.INGESTION_SONAR_SECRET }} sonar_ingestion