Skip to content

Separated model load and audio file for separation from init, to allo… #16

Separated model load and audio file for separation from init, to allo…

Separated model load and audio file for separation from init, to allo… #16

name: publish-to-docker
on:
push:
paths:
- pyproject.toml
workflow_dispatch:
jobs:
build-and-push-docker:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.x'
- name: Install TOML
run: pip install toml
- name: Get version from pyproject.toml
run: |
VERSION=$(python -c "import toml; print(toml.load('pyproject.toml')['tool']['poetry']['version'])")
echo "VERSION=$VERSION" >> $GITHUB_ENV
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push Docker image for CPU
if: ${{ github.ref == 'refs/heads/main' }}
uses: docker/build-push-action@v5
with:
file: Dockerfile.cpu
context: .
platforms: linux/amd64,linux/arm64
push: true
tags: |
beveradb/audio-separator:cpu-${{ env.VERSION }}
beveradb/audio-separator:cpu
beveradb/audio-separator:latest
- name: Build and push Docker image for GPU
if: ${{ github.ref == 'refs/heads/main' }}
uses: docker/build-push-action@v5
with:
file: Dockerfile.gpu
context: .
platforms: linux/amd64
push: true
tags: |
beveradb/audio-separator:gpu-${{ env.VERSION }}
beveradb/audio-separator:gpu
# - name: Build and push Docker image for Runpod
# if: ${{ github.ref == 'refs/heads/main' }}
# uses: docker/build-push-action@v5
# with:
# file: Dockerfile.runpod
# context: .
# platforms: linux/amd64
# push: true
# tags: |
# beveradb/audio-separator:runpod-${{ env.VERSION }}
# beveradb/audio-separator:runpod