This repository has been archived by the owner on Oct 11, 2024. It is now read-only.
feat(router): make the router immune to missing trailing slashes (#148) #99
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: push | |
on: | |
push: | |
branches: main | |
env: | |
BACKEND_IMAGE_NAME: companion | |
DEMO_IMAGE_NAME: gradio | |
DOCKERHUB_USER: ${{ secrets.DOCKERHUB_USER }} | |
jobs: | |
docker: | |
runs-on: ubuntu-latest | |
permissions: | |
packages: write | |
contents: read | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: 3.9 | |
architecture: x64 | |
- uses: abatilo/actions-poetry@v3 | |
with: | |
poetry-version: "1.7.1" | |
- name: Resolve dependencies | |
run: | | |
poetry export -f requirements.txt --without-hashes --output requirements.txt | |
poetry export -f requirements.txt --without-hashes --only demo --output demo/requirements.txt | |
- name: Build docker images | |
run: | | |
docker build -f src/Dockerfile . -t $DOCKERHUB_USER/$BACKEND_IMAGE_NAME:latest | |
docker build -f demo/Dockerfile . -t $DOCKERHUB_USER/$DEMO_IMAGE_NAME:latest | |
- name: Login to DockerHub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.DOCKERHUB_USER }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- name: Push to hub | |
run: | | |
docker push $DOCKERHUB_USER/$BACKEND_IMAGE_NAME:latest | |
docker push $DOCKERHUB_USER/$DEMO_IMAGE_NAME:latest | |
- name: Login to GHCR | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Push to container registry | |
run: | | |
IMAGE_ID=ghcr.io/${{ github.repository_owner }}/$BACKEND_IMAGE_NAME | |
IMAGE_ID=$(echo $IMAGE_ID | tr '[A-Z]' '[a-z]') | |
docker tag $DOCKERHUB_USER/$BACKEND_IMAGE_NAME:latest $IMAGE_ID:latest | |
docker push $IMAGE_ID:latest | |
IMAGE_ID=ghcr.io/${{ github.repository_owner }}/$DEMO_IMAGE_NAME | |
IMAGE_ID=$(echo $IMAGE_ID | tr '[A-Z]' '[a-z]') | |
docker tag $DOCKERHUB_USER/$DEMO_IMAGE_NAME:latest $IMAGE_ID:latest | |
docker push $IMAGE_ID:latest | |
deploy-dev: | |
needs: docker | |
runs-on: ubuntu-latest | |
steps: | |
- uses: appleboy/[email protected] | |
with: | |
host: ${{ secrets.SSH_DEV_HOST }} | |
username: ${{ secrets.SSH_DEV_USERNAME }} | |
key: ${{ secrets.SSH_DEPLOY_DEV }} | |
script: | | |
# Ensure we have max disk space | |
docker rm -fv $(docker ps -aq) | |
docker rmi -f $(docker images -f "dangling=true" -q) | |
docker volume rm -f $(docker volume ls -f "dangling=true" -q) | |
# Update the service | |
docker compose pull backend gradio | |
docker compose stop backend gradio && docker compose up -d --wait | |
# Check update | |
docker inspect -f '{{ .Created }}' $(docker compose images -q backend) | |
docker inspect -f '{{ .Created }}' $(docker compose images -q gradio) | |
# Clean up | |
docker rm -fv $(docker ps -aq) | |
docker rmi -f $(docker images -f "dangling=true" -q) | |
docker volume rm -f $(docker volume ls -f "dangling=true" -q) | |
- name: Ping server | |
env: | |
DEV_ENDPOINT: ${{ secrets.DEV_ENDPOINT }} | |
run: sleep 10 && curl $DEV_ENDPOINT |