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: jobs:
backend-test: backend-test:
runs-on: [docker] runs-on: [docker]
env:
UNIQUE_DB: test_db_${{ github.run_id }}
services: services:
postgres: postgres:
@ -22,7 +24,7 @@ jobs:
env: env:
POSTGRES_USER: test POSTGRES_USER: test
POSTGRES_PASSWORD: test POSTGRES_PASSWORD: test
POSTGRES_DB: test_db POSTGRES_DB: test_db_${{ github.run_id }}_${{ github.run_attempt }}
options: >- options: >-
--health-cmd pg_isready --health-cmd pg_isready
--health-interval 10s --health-interval 10s
@ -46,6 +48,28 @@ jobs:
python -m pip install --upgrade pip python -m pip install --upgrade pip
pip install --cache-dir /tmp/pip-cache -r requirements/dev.txt 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 - name: Debug cache
run: | run: |
echo "Listing PIP cache files:" echo "Listing PIP cache files:"
@ -59,8 +83,9 @@ jobs:
- name: Run tests - name: Run tests
env: env:
TEST_DATABASE_URL: postgresql://test:test@postgres:5432/test_db UNIQUE_DB: test_db_${{ github.run_id }}
DATABASE_URL: postgresql://test:test@postgres:5432/test_db 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 SECRET_KEY: test-secret-key
JWT_SECRET_KEY: test-jwt-secret JWT_SECRET_KEY: test-jwt-secret
FLASK_ENV: test FLASK_ENV: test