name: Create and publish a Docker image on: push: branches: ['main', 'chore/*', 'feature/*', 'bug/*'] env: REGISTRY: ghcr.io IMAGE_NAME: ${{ github.repository }} SQLALCHEMY_DATABASE_URI: "postgresql://postgres:postgres@localhost:5432/pb_test" PGPASSWORD: postgres jobs: sonarcloud: runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@v2 with: # Disabling shallow clone is recommended for improving relevancy of reporting fetch-depth: 0 - name: SonarCloud Scan uses: sonarsource/sonarcloud-github-action@master with: args: > -Dsonar.organization=sartography env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} run_tests: runs-on: ubuntu-latest services: postgres: image: postgres env: POSTGRES_PASSWORD: postgres options: >- --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 ports: - 5432:5432 steps: - name: Checkout repository uses: actions/checkout@v2 - uses: browser-actions/setup-chrome@latest with: chrome-version: stable - uses: actions/setup-python@v3 with: python-version: '3.9' architecture: 'x64' - name: Setup Database run: psql -h localhost -c 'create database pb_test;' -U postgres - name: Upgrade pip run: | pip install --constraint=.github/workflows/constraints.txt pip pip --version - name: Upgrade pip in virtual environments shell: python run: | import os import pip with open(os.environ["GITHUB_ENV"], mode="a") as io: print(f"VIRTUALENV_PIP={pip.__version__}", file=io) - name: Install Poetry run: | pipx install --pip-args=--constraint=.github/workflows/constraints.txt poetry poetry --version - name: Run the tests run: poetry run coverage run -m pytest build-and-push-image: needs: - run_tests runs-on: ubuntu-latest permissions: contents: read packages: write steps: - name: Checkout repository uses: actions/checkout@v2 - name: Log in to the Container registry uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 with: registry: ${{ env.REGISTRY }} username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} - name: Extract metadata (tags, labels) for Docker id: meta uses: docker/metadata-action@98669ae865ea3cffbcbaa878cf57c20bbf1c6c38 with: images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} - name: Build and push Docker image uses: docker/build-push-action@ad44023a93711e3deb337508980b4b5e9bcdc5dc with: context: . push: true tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }}