From ac3994d040a63291113277cf6fd99e2c5fb12196 Mon Sep 17 00:00:00 2001 From: John Marcou Date: Mon, 9 Sep 2024 15:18:57 -0400 Subject: [PATCH] PM-1929 - Configure CI to build and publish the docker image --- .github/workflows/build-publish.yaml | 65 ++++++++++++++++++++++++++++ Dockerfile | 7 ++- setup.py | 4 +- 3 files changed, 73 insertions(+), 3 deletions(-) create mode 100644 .github/workflows/build-publish.yaml diff --git a/.github/workflows/build-publish.yaml b/.github/workflows/build-publish.yaml new file mode 100644 index 0000000..b677d6d --- /dev/null +++ b/.github/workflows/build-publish.yaml @@ -0,0 +1,65 @@ +name: Build - publish + +on: + push: + branches: + - main + workflow_dispatch: + inputs: + docker_tag_suffix: + description: "Enter a Docker Tag suffix (e.g dev)\nSuffixed images will not be auto-deployed" + required: false + type: string + +env: + ECR_REPOSITORY_URL: 673156464838.dkr.ecr.us-west-2.amazonaws.com + ECR_REPOSITORY_NAME: pgt-leader-bot + +jobs: + build-publish: + name: Build and Publish Docker Image + runs-on: minafoundation-default-runners + steps: + - name: 📥 Checkout + uses: actions/checkout@v4 + + - name: 🦀 Get application version from setup.py + id: application-version + run: | + version=$(grep "version" setup.py | head -1 | cut -d'"' -f2) + echo "current-version=$version" >> "$GITHUB_OUTPUT" + + - name: 🏷️ Generate Tag + run: | + if [ "${{ github.event_name }}" == "workflow_dispatch" ]; then + if [ "${{ github.event.inputs.docker_tag_suffix }}" != "" ]; then + echo "TAG=${{ steps.application-version.outputs.current-version }}-${{ github.event.inputs.docker_tag_suffix }}" >> $GITHUB_ENV + else + echo "TAG=${{ steps.application-version.outputs.current-version }}" >> $GITHUB_ENV + fi + elif [ "${{ github.event_name }}" == "push" ] && [ -n "${{ github.event.ref }}" ]; then + echo "TAG=${{ steps.application-version.outputs.current-version }}" >> $GITHUB_ENV + else + echo "Invalid event. Exiting..." + exit 1 + fi + + - name: 🔑 ECR Login + id: login-ecr + uses: aws-actions/amazon-ecr-login@v2 + + - name: 🔍 Check if Tag already exists + id: checktag + uses: tyriis/docker-image-tag-exists@main + with: + registry: ${{ env.ECR_REPOSITORY_URL}} + repository: ${{ env.ECR_REPOSITORY_NAME }} + tag: ${{ env.TAG }} + + - name: 🛠️ Build and Push Docker + uses: mr-smithers-excellent/docker-build-push@v6 + if: steps.checktag.outputs.tag == 'not found' + with: + image: ${{ env.ECR_REPOSITORY_NAME }} + registry: ${{ env.ECR_REPOSITORY_URL }} + tags: ${{ env.TAG }} diff --git a/Dockerfile b/Dockerfile index 8c04664..b37ee3e 100644 --- a/Dockerfile +++ b/Dockerfile @@ -6,7 +6,12 @@ COPY requirements.txt . RUN pip install --no-cache-dir -r requirements.txt -COPY . . +COPY github_tracker_bot github_tracker_bot +COPY leader_bot leader_bot +COPY utils utils +COPY config.py . +COPY log_config.py . +COPY __init__.py . # Possible [ github_tracker_bot/bot.py (default), leader_bot/bot.py ] CMD ["python", "github_tracker_bot/bot.py"] diff --git a/setup.py b/setup.py index ca44a43..306b421 100644 --- a/setup.py +++ b/setup.py @@ -1,7 +1,7 @@ -from setuptools import setup, find_packages +from setuptools import find_packages, setup setup( name="pgt_leaderbot", - version="0.1", + version="0.3.1", packages=find_packages(), )