Skip to content

what

what #31

Workflow file for this run

name: DB Change Checks
on:
push
jobs:
check-sql-schema-changes:
runs-on: ubuntu-latest
steps:
- name: 1. Checkout Main Branch
uses: actions/checkout@v4
with:
fetch-depth: 1
token: ${{ secrets.GITHUB_TOKEN }}
- name: 2. Check For Changes
id: changed-db-files
uses: tj-actions/changed-files@v44
with:
files: |
- "app"
- name: 3. Set up Python
id: setup-python
uses: actions/setup-python@v5
if: steps.check-sql-schema-changes.outputs.any_changed == 'true'
with:
python-version: '3.11'
- name: 4. Generate envs
id: generate-envs
if: steps.check-sql-schema-changes.outputs.any_changed == 'true'
run: |
TIMESTAMP=$(date +'%Y%m%d%H%M')
BRANCH_NAME="my-branch-$TIMESTAMP"
DATABASE_URL="abcd"
echo "BRANCH_NAME=$BRANCH_NAME" >> $GITHUB_ENV
echo "DATABASE_URL=$DATABASE_URL" >> $GITHUB_ENV
- name: 5. Install alembic
if: steps.check-sql-schema-changes.outputs.any_changed == 'true'
run: |
python -m pip install --upgrade pip
pip install -r app/requirements.txt
- name: 6. Run alembic script autogeneration
if: steps.check-sql-schema-changes.outputs.any_changed == 'true'
id: run-alembic-script-autogen
env:
DATABASE_URL: ${{ secrets.DATABASE_URL }}
run: |
alembic -c alembic.ini revision --autogenerate -m "test script {{ env.BRANCH_NAME }}"
- name: 7. Checkout new branch
if: steps.check-sql-schema-changes.outputs.any_changed == 'true'
id: checkout-new-branch
run: |
git config --global user.email "github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions[bot]"
git checkout -b ${{ env.BRANCH_NAME }}
git push origin ${{ env.BRANCH_NAME }}
- name: 8. Add-alembic-script-to-new-branch
if: steps.check-sql-schema-changes.outputs.any_changed == 'true'
run: |
git add .
git commit -m "Add new Alembic migration"
git push origin HEAD:${{ github.ref }}
- name: 9. Create PR
if: steps.check-sql-schema-changes.outputs.any_changed == 'true'
id: create-pull-request
uses: peter-evans/create-pull-request@v5
with:
branch: ${{ env.BRANCH_NAME }}
base: main
title: "BotPR: {{ env.BRANCH_NAME }}"
author: "github-actions[bot] <github-actions[bot]@users.noreply.github.com>"