-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
build: ensure the migration diff is displayed
- Loading branch information
1 parent
b6f0732
commit 12b0ff7
Showing
3 changed files
with
206 additions
and
204 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,108 @@ | ||
name: Check database migration | ||
on: | ||
pull_request: | ||
branches: | ||
- 'main' | ||
paths: | ||
- 'packages/domain/prisma/migrations/**' | ||
|
||
jobs: | ||
migration-detail: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Setup pscale | ||
uses: planetscale/setup-pscale-action@v1 | ||
|
||
- name: Set database branch name | ||
run: echo "PSCALE_BRANCH_NAME=$(echo ${{ github.head_ref }} | tr -cd '[:alnum:]-'| tr '[:upper:]' '[:lower:]')" >> $GITHUB_ENV | ||
|
||
- name: Create deploy request on development branch | ||
env: | ||
PLANETSCALE_SERVICE_TOKEN_ID: ${{ secrets.PLANETSCALE_SERVICE_TOKEN_ID }} | ||
PLANETSCALE_SERVICE_TOKEN: ${{ secrets.PLANETSCALE_SERVICE_TOKEN }} | ||
run: | | ||
set +e | ||
pscale deploy-request show ${{ secrets.PLANETSCALE_DATABASE_NAME }} ${{ env.PSCALE_BRANCH_NAME }} --org ${{ secrets.PLANETSCALE_ORG_NAME }} | ||
exit_code=$? | ||
set -e | ||
if [ $exit_code -eq 0 ]; then | ||
echo "Deploy request exists. Skipping creation." | ||
else | ||
echo "Deploy request does not exist. Creating." | ||
pscale deploy-request create ${{ secrets.PLANETSCALE_DATABASE_NAME }} ${{ env.PSCALE_BRANCH_NAME }} \ | ||
--org ${{ secrets.PLANETSCALE_ORG_NAME }} \ | ||
--into dev \ | ||
--notes "Apply changes to the dev branch" | ||
fi | ||
- name: Get deploy request number | ||
env: | ||
PLANETSCALE_SERVICE_TOKEN_ID: ${{ secrets.PLANETSCALE_SERVICE_TOKEN_ID }} | ||
PLANETSCALE_SERVICE_TOKEN: ${{ secrets.PLANETSCALE_SERVICE_TOKEN }} | ||
run: | | ||
DEPLOY_REQUEST_NUMBER=$(pscale deploy-request show ${{ secrets.PLANETSCALE_DATABASE_NAME }} ${{ env.PSCALE_BRANCH_NAME }} --org ${{ secrets.PLANETSCALE_ORG_NAME }} -f json | jq -r '.number') | ||
echo "DEPLOY_REQUEST_NUMBER=$DEPLOY_REQUEST_NUMBER" >> $GITHUB_ENV | ||
- name: Check deployment state | ||
continue-on-error: false | ||
env: | ||
PLANETSCALE_SERVICE_TOKEN_ID: ${{ secrets.PLANETSCALE_SERVICE_TOKEN_ID }} | ||
PLANETSCALE_SERVICE_TOKEN: ${{ secrets.PLANETSCALE_SERVICE_TOKEN }} | ||
run: | | ||
for i in {1..10}; do | ||
DEPLOYMENT_STATE=$(pscale deploy-request show ${{ secrets.PLANETSCALE_DATABASE_NAME }} ${{ env.DEPLOY_REQUEST_NUMBER }} --org ${{ secrets.PLANETSCALE_ORG_NAME }} --format json | jq -r '.deployment_state') | ||
echo "Deployment State: $DEPLOYMENT_STATE" | ||
if [ "$DEPLOYMENT_STATE" = "ready" ]; then | ||
echo "Deployment state is ready. Continuing." | ||
echo "DEPLOY_REQUEST_OPENED=true" >> $GITHUB_ENV | ||
break | ||
fi | ||
echo "Deployment state is not ready. Waiting 2 seconds before checking again." | ||
sleep 2 | ||
done | ||
- name: Collect the migration diff | ||
continue-on-error: false | ||
if: ${{ env.DEPLOY_REQUEST_OPENED }} | ||
env: | ||
PLANETSCALE_SERVICE_TOKEN_ID: ${{ secrets.PLANETSCALE_SERVICE_TOKEN_ID }} | ||
PLANETSCALE_SERVICE_TOKEN: ${{ secrets.PLANETSCALE_SERVICE_TOKEN }} | ||
run: | | ||
deploy_data=$(pscale api organizations/${{ secrets.PLANETSCALE_ORG_NAME }}/databases/${{ secrets.PLANETSCALE_DATABASE_NAME }}/deploy-requests/${{ env.DEPLOY_REQUEST_NUMBER }}/deployment --org planetscale) | ||
can_drop_data=$(echo "$deploy_data" | jq -r '.deploy_operations[] | select(.can_drop_data == true) | .can_drop_data') | ||
echo "Deploy request opened: https://app.planetscale.com/${{ secrets.PLANETSCALE_ORG_NAME }}/${{ secrets.PLANETSCALE_DATABASE_NAME }}/deploy-requests/${{ env.DEPLOY_REQUEST_NUMBER }}" >> migration-message.txt | ||
echo "" >> migration-message.txt | ||
if [ "$can_drop_data" = "true" ]; then | ||
echo ":rotating_light: You are dropping a column. Before running the migration make sure to do the following:" >> migration-message.txt | ||
echo "" >> migration-message.txt | ||
echo "1. [ ] Deploy app changes to ensure the column is no longer being used." >> migration-message.txt | ||
echo "2. [ ] Once you've verified it's no used, run the deploy request." >> migration-message.txt | ||
echo "" >> migration-message.txt | ||
else | ||
echo "When adding to the schema, the Deploy Request must be run **before** the code is deployed." >> migration-message.txt | ||
echo "Please ensure your schema changes are compatible with the application code currently running in production." >> migration-message.txt | ||
echo "" >> migration-message.txt | ||
echo "1. [ ] Successfully run the Deploy Request" >> migration-message.txt | ||
echo "2. [ ] Deploy this PR" >> migration-message.txt | ||
echo "" >> migration-message.txt | ||
fi | ||
echo "\`\`\`diff" >> migration-message.txt | ||
pscale deploy-request diff ${{ secrets.PLANETSCALE_DATABASE_NAME }} ${{ env.DEPLOY_REQUEST_NUMBER }} --org ${{ secrets.PLANETSCALE_ORG_NAME }} -f json | jq -r '.[].raw' >> migration-message.txt | ||
echo "\`\`\`" >> migration-message.txt | ||
- name: Comment pull request with the migration diff | ||
uses: thollander/actions-comment-pull-request@v2 | ||
if: ${{ env.DEPLOY_REQUEST_OPENED }} | ||
with: | ||
filePath: migration-message.txt |
Oops, something went wrong.