name: Run tests & Publish to Docker Registry on: push: pull_request: types: [ 'opened' ] jobs: test: runs-on: ubuntu-latest strategy: max-parallel: 4 matrix: python-version: [3.7, "3.10"] # service containers to run with `postgres-job` services: # label used to access the service container postgres: # Docker Hub image image: postgres:13 # service environment variables # `POSTGRES_HOST` is `postgres` env: # optional (defaults to `postgres`) POSTGRES_DB: test # required POSTGRES_PASSWORD: test # optional (defaults to `5432`) POSTGRES_PORT: 5432 # optional (defaults to `postgres`) POSTGRES_USER: test ports: - 15432:5432 # set health checks to wait until postgres has started options: >- --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 steps: - name: Check out repository uses: actions/checkout@v2 - name: Set up Python ${{ matrix.python-version }} uses: actions/setup-python@v2 with: python-version: ${{ matrix.python-version }} - name: Install poetry uses: snok/install-poetry@v1 with: virtualenvs-create: true virtualenvs-in-project: true installer-parallel: true - name: Run caching id: cached-poetry-dependencies uses: actions/cache@v2 with: path: .venv key: venv-${{ runner.os }}-${{ matrix.python-version }}-${{ hashFiles('**/poetry.lock') }} - name: Install OS dependencies if: ${{ matrix.python-version }} == '3.10' run: | sudo apt update sudo apt install -y libre2-dev libpq-dev - name: Install dependencies if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true' run: poetry install --no-interaction --no-root - name: Install library run: poetry install --no-interaction - name: Check formatting & linting run: | poetry run black --check . poetry run flake8 - name: Run db migration run: | CONFIG=tests/test.env poetry run alembic upgrade head - name: Test with pytest run: | poetry run pytest env: GITHUB_ACTIONS_TEST: true - name: Archive code coverage results uses: actions/upload-artifact@v2 with: name: code-coverage-report path: htmlcov build: runs-on: ubuntu-latest needs: ['test'] if: github.event_name == 'push' && (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/v')) steps: - name: Docker meta id: meta uses: docker/metadata-action@v4 with: images: simplelogin/app-ci - name: Login to Docker Hub uses: docker/login-action@v2 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_PASSWORD }} # We need to checkout the repository in order for the "Create Sentry release" to work - name: Checkout repository uses: actions/checkout@v2 - name: Prepare version file run: | echo "${{ github.ref }}" > .version - name: Build image and publish to Docker Registry uses: docker/build-push-action@v3 with: context: . push: true tags: ${{ steps.meta.outputs.tags }} - name: Create Sentry release uses: getsentry/action-release@v1 env: SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} SENTRY_ORG: ${{ secrets.SENTRY_ORG }} SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }} - name: Send Telegram message uses: appleboy/telegram-action@master with: to: ${{ secrets.TELEGRAM_TO }} token: ${{ secrets.TELEGRAM_TOKEN }} args: Docker image pushed on ${{ github.ref }} # If we have generated a tag, generate the changelog, send a notification to slack and create the GitHub release - name: Build Changelog id: build_changelog if: startsWith(github.ref, 'refs/tags/v') uses: mikepenz/release-changelog-builder-action@v3 with: configuration: ".github/changelog_configuration.json" env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - name: Prepare Slack notification contents if: startsWith(github.ref, 'refs/tags/v') run: | changelog=$(cat << EOH ${{ steps.build_changelog.outputs.changelog }} EOH ) messageWithoutNewlines=$(echo "${changelog}" | awk '{printf "%s\\n", $0}') messageWithoutDoubleQuotes=$(echo "${messageWithoutNewlines}" | sed "s/\"/'/g") echo "${messageWithoutDoubleQuotes}" echo "SLACK_CHANGELOG=${messageWithoutDoubleQuotes}" >> $GITHUB_ENV - name: Post notification to Slack uses: slackapi/slack-github-action@v1.19.0 if: startsWith(github.ref, 'refs/tags/v') with: channel-id: ${{ secrets.SLACK_CHANNEL_ID }} payload: | { "blocks": [ { "type": "header", "text": { "type": "plain_text", "text": "New tag created", "emoji": true } }, { "type": "section", "text": { "type": "mrkdwn", "text": "*Tag: ${{ github.ref_name }}*" } }, { "type": "section", "text": { "type": "mrkdwn", "text": "*Changelog:*\n${{ env.SLACK_CHANGELOG }}" } } ] } env: SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }} - name: Create GitHub Release if: startsWith(github.ref, 'refs/tags/v') uses: actions/create-release@v1 with: tag_name: ${{ github.ref }} release_name: ${{ github.ref }} body: ${{ steps.build_changelog.outputs.changelog }} env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}