Skip to content
This repository has been archived by the owner on Oct 11, 2024. It is now read-only.

build(deps-dev): bump ruff from 0.3.5 to 0.3.7 (#150) #101

build(deps-dev): bump ruff from 0.3.5 to 0.3.7 (#150)

build(deps-dev): bump ruff from 0.3.5 to 0.3.7 (#150) #101

Workflow file for this run

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