Fix build et actions
Some checks failed
Build and Push Docker Images / Build Backend Image (push) Failing after 37s
Build and Push Docker Images / Build Frontend Image (push) Has been cancelled

This commit is contained in:
2025-12-23 13:23:07 +01:00
parent 8ec8b1aa42
commit 3e225b158f
8 changed files with 104 additions and 31 deletions

View File

@@ -10,7 +10,8 @@
"Bash(curl:*)", "Bash(curl:*)",
"Bash(docker logs:*)", "Bash(docker logs:*)",
"Bash(docker exec:*)", "Bash(docker exec:*)",
"Bash(ls:*)" "Bash(ls:*)",
"Bash(docker build:*)"
] ]
} }
} }

View File

@@ -36,8 +36,8 @@ jobs:
- name: Determine version - name: Determine version
id: version id: version
run: | run: |
if [[ "${{ github.ref }}" == refs/tags/v* ]]; then if [[ "${{ gitea.ref }}" == refs/tags/v* ]]; then
echo "VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT echo "VERSION=${GITEA_REF#refs/tags/}" >> $GITHUB_OUTPUT
else else
echo "VERSION=dev-$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT echo "VERSION=dev-$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
fi fi
@@ -50,9 +50,9 @@ jobs:
tags: | tags: |
type=semver,pattern={{version}} type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}} type=semver,pattern={{major}}.{{minor}}
type=raw,value=latest,enable=${{ startsWith(github.ref, 'refs/tags/v') }} type=raw,value=latest,enable=${{ startsWith(gitea.ref, 'refs/tags/v') }}
type=raw,value=dev,enable=${{ github.ref == 'refs/heads/main' }} type=raw,value=dev,enable=${{ gitea.ref == 'refs/heads/main' }}
type=sha,prefix=dev-,format=short,enable=${{ github.ref == 'refs/heads/main' }} type=sha,prefix=dev-,format=short,enable=${{ gitea.ref == 'refs/heads/main' }}
- name: Build and push backend - name: Build and push backend
uses: docker/build-push-action@v5 uses: docker/build-push-action@v5
@@ -90,8 +90,8 @@ jobs:
- name: Determine version - name: Determine version
id: version id: version
run: | run: |
if [[ "${{ github.ref }}" == refs/tags/v* ]]; then if [[ "${{ gitea.ref }}" == refs/tags/v* ]]; then
echo "VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT echo "VERSION=${GITEA_REF#refs/tags/}" >> $GITHUB_OUTPUT
else else
echo "VERSION=dev-$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT echo "VERSION=dev-$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
fi fi
@@ -104,9 +104,9 @@ jobs:
tags: | tags: |
type=semver,pattern={{version}} type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}} type=semver,pattern={{major}}.{{minor}}
type=raw,value=latest,enable=${{ startsWith(github.ref, 'refs/tags/v') }} type=raw,value=latest,enable=${{ startsWith(gitea.ref, 'refs/tags/v') }}
type=raw,value=dev,enable=${{ github.ref == 'refs/heads/main' }} type=raw,value=dev,enable=${{ gitea.ref == 'refs/heads/main' }}
type=sha,prefix=dev-,format=short,enable=${{ github.ref == 'refs/heads/main' }} type=sha,prefix=dev-,format=short,enable=${{ gitea.ref == 'refs/heads/main' }}
- name: Build and push frontend - name: Build and push frontend
uses: docker/build-push-action@v5 uses: docker/build-push-action@v5

View File

@@ -14,7 +14,7 @@ Le système est **100% autonome** - aucune action manuelle requise ! Les modèle
1. **Cloner le projet** : 1. **Cloner le projet** :
```bash ```bash
git clone <votre-repo> git clone https://git.benoitsz.com/benoit/Audio-Classifier.git
cd Audio-Classifier cd Audio-Classifier
``` ```
@@ -36,6 +36,8 @@ docker-compose up -d
C'est tout ! 🎉 C'est tout ! 🎉
**Note** : Les images Docker sont automatiquement téléchargées depuis git.benoitsz.com. Aucun build nécessaire !
### Premier Scan ### Premier Scan
1. Ouvrir http://localhost:3000 1. Ouvrir http://localhost:3000

View File

@@ -41,8 +41,8 @@ Outil de classification audio automatique capable d'indexer et analyser des bibl
```bash ```bash
# 1. Cloner le projet # 1. Cloner le projet
git clone <repo> git clone https://git.benoitsz.com/benoit/Audio-Classifier.git
cd audio-classifier cd Audio-Classifier
# 2. Configurer le chemin audio (optionnel) # 2. Configurer le chemin audio (optionnel)
echo "AUDIO_LIBRARY_PATH=/chemin/vers/votre/musique" > .env echo "AUDIO_LIBRARY_PATH=/chemin/vers/votre/musique" > .env
@@ -53,6 +53,8 @@ docker-compose up -d
**C'est tout !** 🎉 **C'est tout !** 🎉
Les images Docker sont automatiquement téléchargées depuis le registry Gitea.
- Frontend : http://localhost:3000 - Frontend : http://localhost:3000
- API : http://localhost:8001 - API : http://localhost:8001
- API Docs : http://localhost:8001/docs - API Docs : http://localhost:8001/docs
@@ -66,13 +68,22 @@ docker-compose up -d
### ✨ Particularités ### ✨ Particularités
- **Aucun téléchargement manuel** : Les modèles Essentia (28 MB) sont inclus dans l'image Docker - **Images pré-construites** : Téléchargées automatiquement depuis git.benoitsz.com
- **Modèles inclus** : Les modèles Essentia (28 MB) sont intégrés dans l'image
- **Aucune configuration** : Tout fonctionne out-of-the-box - **Aucune configuration** : Tout fonctionne out-of-the-box
- **Transcodage automatique** : MP3 128kbps créés pour streaming rapide - **Transcodage automatique** : MP3 128kbps créés pour streaming rapide
- **Waveforms pré-calculées** : Chargement instantané - **Waveforms pré-calculées** : Chargement instantané
📖 **Documentation complète** : Voir [DEPLOYMENT.md](DEPLOYMENT.md) 📖 **Documentation complète** : Voir [DEPLOYMENT.md](DEPLOYMENT.md)
### 🛠 Build local (développement)
Si vous voulez builder les images localement :
```bash
docker-compose -f docker-compose.build.yml build
docker-compose -f docker-compose.build.yml up -d
```
## 📖 Utilisation ## 📖 Utilisation
### Scanner un dossier ### Scanner un dossier

View File

@@ -32,7 +32,7 @@ WORKDIR /app
RUN pip install --no-cache-dir --upgrade pip setuptools wheel RUN pip install --no-cache-dir --upgrade pip setuptools wheel
# Copy requirements # Copy requirements
COPY requirements.txt . COPY backend/requirements.txt .
# Install Python dependencies in stages for better caching # Install Python dependencies in stages for better caching
# Using versions compatible with Python 3.9 # Using versions compatible with Python 3.9
@@ -45,10 +45,11 @@ RUN pip install --no-cache-dir essentia-tensorflow
RUN pip install --no-cache-dir -r requirements.txt RUN pip install --no-cache-dir -r requirements.txt
# Copy application code # Copy application code
COPY src/ ./src/ COPY backend/src/ ./src/
COPY alembic.ini . COPY backend/alembic.ini .
COPY src/models/ ./models/ # Copy Essentia models into image (28 MB total)
COPY backend/models/ ./models/
RUN ls -lh /app/models RUN ls -lh /app/models
# Expose port # Expose port

64
docker-compose.build.yml Normal file
View File

@@ -0,0 +1,64 @@
# Docker Compose pour build local (développement)
# Usage: docker-compose -f docker-compose.build.yml build
services:
postgres:
image: pgvector/pgvector:pg16
container_name: audio_classifier_db
environment:
POSTGRES_USER: ${POSTGRES_USER:-audio_user}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-audio_password}
POSTGRES_DB: ${POSTGRES_DB:-audio_classifier}
ports:
- "5433:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
- ./backend/init-db.sql:/docker-entrypoint-initdb.d/init-db.sql
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-audio_user}"]
interval: 10s
timeout: 5s
retries: 5
restart: unless-stopped
backend:
build:
context: .
dockerfile: backend/Dockerfile
container_name: audio_classifier_api
depends_on:
postgres:
condition: service_healthy
environment:
DATABASE_URL: postgresql://${POSTGRES_USER:-audio_user}:${POSTGRES_PASSWORD:-audio_password}@postgres:5432/${POSTGRES_DB:-audio_classifier}
CORS_ORIGINS: ${CORS_ORIGINS:-http://localhost:3000}
ANALYSIS_USE_CLAP: ${ANALYSIS_USE_CLAP:-false}
ANALYSIS_NUM_WORKERS: ${ANALYSIS_NUM_WORKERS:-4}
ESSENTIA_MODELS_PATH: /app/models
ports:
- "8001:8000"
volumes:
# Mount your audio library (read-write for transcoding and waveforms)
- ${AUDIO_LIBRARY_PATH:-./audio_samples}:/audio
restart: unless-stopped
frontend:
build:
context: .
dockerfile: frontend/Dockerfile
args:
NEXT_PUBLIC_API_URL: http://localhost:8001
container_name: audio_classifier_ui
environment:
# Use localhost:8001 because the browser (client-side) needs to access the API
# The backend is mapped to port 8001 on the host machine
NEXT_PUBLIC_API_URL: http://localhost:8001
ports:
- "3000:3000"
depends_on:
- backend
restart: unless-stopped
volumes:
postgres_data:
driver: local

View File

@@ -19,7 +19,7 @@ services:
restart: unless-stopped restart: unless-stopped
backend: backend:
build: ./backend image: git.benoitsz.com/benoit/audio-classifier-backend:latest
container_name: audio_classifier_api container_name: audio_classifier_api
depends_on: depends_on:
postgres: postgres:
@@ -38,10 +38,7 @@ services:
restart: unless-stopped restart: unless-stopped
frontend: frontend:
build: image: git.benoitsz.com/benoit/audio-classifier-frontend:latest
context: ./frontend
args:
NEXT_PUBLIC_API_URL: http://localhost:8001
container_name: audio_classifier_ui container_name: audio_classifier_ui
environment: environment:
# Use localhost:8001 because the browser (client-side) needs to access the API # Use localhost:8001 because the browser (client-side) needs to access the API

View File

@@ -4,16 +4,13 @@ FROM node:20-alpine
WORKDIR /app WORKDIR /app
# Copy package files # Copy package files
COPY package*.json ./ COPY frontend/package*.json ./
# Debug: List files and Node.js version # Install dependencies
RUN ls -la && node --version && npm --version RUN npm ci
# Install dependencies with more verbose output
RUN npm install --verbose
# Copy application code # Copy application code
COPY . . COPY frontend/ .
# Build argument for API URL # Build argument for API URL
ARG NEXT_PUBLIC_API_URL=http://localhost:8001 ARG NEXT_PUBLIC_API_URL=http://localhost:8001