unique db action run

This commit is contained in:
david 2026-05-01 18:08:35 +03:00
parent f407285e60
commit 8e138689cf

View file

@ -15,6 +15,8 @@ on:
jobs:
backend-test:
runs-on: [docker]
env:
UNIQUE_DB: test_db_${{ github.run_id }}
services:
postgres:
@ -22,7 +24,7 @@ jobs:
env:
POSTGRES_USER: test
POSTGRES_PASSWORD: test
POSTGRES_DB: test_db
POSTGRES_DB: test_db_${{ github.run_id }}_${{ github.run_attempt }}
options: >-
--health-cmd pg_isready
--health-interval 10s
@ -46,6 +48,28 @@ jobs:
python -m pip install --upgrade pip
pip install --cache-dir /tmp/pip-cache -r requirements/dev.txt
- name: Create Unique Test Database
env:
DATABASE_URL: postgresql://test:test@postgres:5432/postgres
run: |
# Install postgresql-client if not present in the alpine image to run psql
# Or use python to create the db
cd backend
python -c "
import os
from sqlalchemy import create_engine, text
db_url = os.environ['DATABASE_URL']
engine = create_engine(db_url)
new_db = os.environ['UNIQUE_DB']
# Connect to default 'postgres' db to create the new one
with engine.connect() as conn:
conn.execute(text('COMMIT')) # Close any open transactions
conn.execute(text(f'DROP DATABASE IF EXISTS {new_db}'))
conn.execute(text(f'CREATE DATABASE {new_db}'))
print(f'Created database: {new_db}')
"
- name: Debug cache
run: |
echo "Listing PIP cache files:"
@ -59,8 +83,9 @@ jobs:
- name: Run tests
env:
TEST_DATABASE_URL: postgresql://test:test@postgres:5432/test_db
DATABASE_URL: postgresql://test:test@postgres:5432/test_db
UNIQUE_DB: test_db_${{ github.run_id }}
TEST_DATABASE_URL: postgresql://test:test@postgres:5432/${{ env.UNIQUE_DB }}
DATABASE_URL: postgresql://test:test@postgres:5432/${{ env.UNIQUE_DB }}
SECRET_KEY: test-secret-key
JWT_SECRET_KEY: test-jwt-secret
FLASK_ENV: test