Skip to content

chore: Handle migration conflicts #5

chore: Handle migration conflicts

chore: Handle migration conflicts #5

Workflow file for this run

name: Migration Order
on:
pull_request:
paths:
- packages/server/postgres/migrations/*.ts
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
migration-order:
runs-on: ubuntu-latest
steps:
- name: Checkout master
uses: actions/checkout@v3
with:
ref: master
- name: Get newest migration on master
run: |
MAX_OLD_MIGRATION=$(ls packages/server/postgres/migrations | tail -n 1)
echo MAX_OLD_MIGRATION=$MAX_OLD_MIGRATION >> $GITHUB_ENV
- name: Checkout PR
uses: actions/checkout@v3
- name: Get new migrations
id: new-migrations
uses: tj-actions/changed-files@v40
with:
files: packages/server/postgres/migrations/*.ts
- name: Check migration conflicts
run: |
for file in ${{ steps.new-migrations.outputs.added_files }}; do
echo "Testing $file"
if [[ "$(basename $file)" < "${{ env.MAX_OLD_MIGRATION }}" ]]; then
echo "Migration $file predates ${{ env.MAX_OLD_MIGRATION}}. Please rename it"
exit 1
else
echo "Migration $file does not conflict with existing migrations on master"
fi
done