From afbd6f9cf57a3af45c6e846e7f05ef459957592b Mon Sep 17 00:00:00 2001 From: Ranjan Shrestha Date: Fri, 8 Nov 2024 12:03:40 +0545 Subject: [PATCH] Add CI for building package fix Add config to push the image; --- .github/workflows/ci.yml | 85 ++++++++++++++++++++++++++++++++++++++++ Dockerfile | 1 + 2 files changed, 86 insertions(+) create mode 100644 .github/workflows/ci.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..76cfdc3 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,85 @@ +name: Run test + +on: + push: + branches: + - develop + - feat/* + pull_request: + +jobs: + test: + name: 🚴 Test 🚴 + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@main + + - name: Login to GitHub Container Registry + uses: docker/login-action@v3 + if: github.event_name == 'push' + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: 🐳 Prepare Docker + id: prep + env: + IMAGE_NAME: ghcr.io/${{ github.repository }} + PUSH_DOCKER_IMAGE: ${{ inputs.push_docker_image }} + run: | + BRANCH_NAME=$(echo $GITHUB_REF_NAME | sed 's|:|-|' | tr '[:upper:]' '[:lower:]' | sed 's/_/-/g' | cut -c1-100 | sed 's/-*$//') + + # XXX: Check if there is a slash in the BRANCH_NAME eg: project/add-docker + if [[ "$BRANCH_NAME" == *"/"* ]]; then + # XXX: Change the docker image package to -beta + IMAGE_NAME="$IMAGE_NAME-beta" + TAG="$(echo "$BRANCH_NAME" | sed 's|/|-|g').$(echo $GITHUB_SHA | head -c7)" + else + TAG="$BRANCH_NAME.$(echo $GITHUB_SHA | head -c7)" + fi + + echo "tagged_image_name=${IMAGE_NAME}" >> $GITHUB_OUTPUT + echo "tag=${TAG}" >> $GITHUB_OUTPUT + echo "tagged_image=${IMAGE_NAME}:${TAG}" >> $GITHUB_OUTPUT + echo "push_docker_image=$PUSH_DOCKER_IMAGE" >> $GITHUB_OUTPUT + echo "::notice::Tagged docker image: ${IMAGE_NAME}:${TAG}" + + - name: 🐳 Set up Docker Buildx + id: buildx + uses: docker/setup-buildx-action@v3 + + - name: 🐳 Cache Docker layers + uses: actions/cache@v4 + with: + path: /tmp/.buildx-cache + key: ${{ runner.os }}-buildx-${{ github.ref }} + restore-keys: | + ${{ runner.os }}-buildx-refs/develop + ${{ runner.os }}-buildx- + + - name: 🐳 Build image + uses: docker/build-push-action@v6 + with: + context: . + builder: ${{ steps.buildx.outputs.name }} + file: Dockerfile + push: ${{ steps.prep.outputs.push_docker_image == 'true' }} + load: true + tags: ${{ steps.prep.outputs.tagged_image }} + cache-from: type=local,src=/tmp/.buildx-cache + cache-to: type=local,dest=/tmp/.buildx-cache-new + + - name: 🐳 Docker push + if: github.event_name == 'push' + uses: docker/build-push-action@v6 + with: + tags: ${{ steps.prep.outputs.tagged_image }} + push: true + + - name: 🐳 Move docker cache (🧙 Hack fix) + run: | + rm -rf /tmp/.buildx-cache + mv /tmp/.buildx-cache-new /tmp/.buildx-cache + diff --git a/Dockerfile b/Dockerfile index 0f38e9c..754fea7 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,6 +1,7 @@ FROM python:3.12-slim-bullseye LABEL maintainer="TC Developers" +LABEL org.opencontainers.image.source="https://github.com/toggle-corp/embedding-models" ENV PYTHONUNBUFFERED 1