117 lines
3.1 KiB
YAML
117 lines
3.1 KiB
YAML
name: DB Migration Test
|
|
|
|
on:
|
|
workflow_call:
|
|
|
|
concurrency:
|
|
group: db-migration-test-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
db-migration-test-postgres:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
persist-credentials: false
|
|
|
|
- name: Setup UV and Python
|
|
uses: astral-sh/setup-uv@v6
|
|
with:
|
|
enable-cache: true
|
|
python-version: "3.12"
|
|
cache-dependency-glob: api/uv.lock
|
|
|
|
- name: Install dependencies
|
|
run: uv sync --project api
|
|
- name: Ensure Offline migration are supported
|
|
run: |
|
|
# upgrade
|
|
uv run --directory api flask db upgrade 'base:head' --sql
|
|
# downgrade
|
|
uv run --directory api flask db downgrade 'head:base' --sql
|
|
|
|
- name: Prepare middleware env
|
|
run: |
|
|
cd docker
|
|
cp middleware.env.example middleware.env
|
|
|
|
- name: Set up Middlewares
|
|
uses: hoverkraft-tech/compose-action@v2.0.2
|
|
with:
|
|
compose-file: |
|
|
docker/docker-compose.middleware.yaml
|
|
services: |
|
|
db_postgres
|
|
redis
|
|
|
|
- name: Prepare configs
|
|
run: |
|
|
cd api
|
|
cp .env.example .env
|
|
|
|
- name: Run DB Migration
|
|
env:
|
|
DEBUG: true
|
|
run: uv run --directory api flask upgrade-db
|
|
|
|
db-migration-test-mysql:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
persist-credentials: false
|
|
|
|
- name: Setup UV and Python
|
|
uses: astral-sh/setup-uv@v6
|
|
with:
|
|
enable-cache: true
|
|
python-version: "3.12"
|
|
cache-dependency-glob: api/uv.lock
|
|
|
|
- name: Install dependencies
|
|
run: uv sync --project api
|
|
- name: Ensure Offline migration are supported
|
|
run: |
|
|
# upgrade
|
|
uv run --directory api flask db upgrade 'base:head' --sql
|
|
# downgrade
|
|
uv run --directory api flask db downgrade 'head:base' --sql
|
|
|
|
- name: Prepare middleware env for MySQL
|
|
run: |
|
|
cd docker
|
|
cp middleware.env.example middleware.env
|
|
sed -i 's/DB_TYPE=postgresql/DB_TYPE=mysql/' middleware.env
|
|
sed -i 's/DB_HOST=db_postgres/DB_HOST=db_mysql/' middleware.env
|
|
sed -i 's/DB_PORT=5432/DB_PORT=3306/' middleware.env
|
|
sed -i 's/DB_USERNAME=postgres/DB_USERNAME=mysql/' middleware.env
|
|
|
|
- name: Set up Middlewares
|
|
uses: hoverkraft-tech/compose-action@v2.0.2
|
|
with:
|
|
compose-file: |
|
|
docker/docker-compose.middleware.yaml
|
|
services: |
|
|
db_mysql
|
|
redis
|
|
|
|
- name: Prepare configs for MySQL
|
|
run: |
|
|
cd api
|
|
cp .env.example .env
|
|
sed -i 's/DB_TYPE=postgresql/DB_TYPE=mysql/' .env
|
|
sed -i 's/DB_PORT=5432/DB_PORT=3306/' .env
|
|
sed -i 's/DB_USERNAME=postgres/DB_USERNAME=root/' .env
|
|
|
|
- name: Run DB Migration
|
|
env:
|
|
DEBUG: true
|
|
run: uv run --directory api flask upgrade-db
|