diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..73ea0fd --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,76 @@ +name: Run test + +on: + push: + - develop + - feat/* + +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: ${{ inputs.push_docker_image }} + 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: 🐳 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