Spike One login implementation #4132
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
name: Pull request checks | |
on: | |
pull_request: | |
branches: [main] | |
paths: | |
- "app/models/**" | |
jobs: | |
warn-enums: | |
name: Detect enum changes | |
runs-on: ubuntu-latest | |
services: | |
postgres: | |
image: postgres:14-alpine | |
env: | |
POSTGRES_PASSWORD: password | |
ports: | |
- 5432:5432 | |
# needed because the postgres container does not provide a healthcheck | |
options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 | |
steps: | |
# Check-out current branch | |
- name: Checkout PR branch | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # all tag/branches history | |
# Install Ruby | |
- name: Set up Ruby (installs .ruby-version, runs bundle install) | |
uses: ruby/setup-ruby@v1 | |
with: | |
bundler-cache: true | |
# Use .env.example | |
- name: Use .env.example as .env | |
run: cp .env.example .env | |
# Set up development database | |
- name: Setup development database | |
run: bundle exec rails db:setup | |
env: | |
DB_HOSTNAME: localhost | |
DB_USERNAME: postgres | |
DB_PASSWORD: password | |
DB_PORT: 5432 | |
# Get all enums in changed models | |
- name: Check for changed enums | |
run: bundle exec ruby .github/scripts/enums_in_models.rb >enums_after.log | |
env: | |
DB_HOSTNAME: localhost | |
DB_USERNAME: postgres | |
DB_PASSWORD: password | |
DB_PORT: 5432 | |
# Keep a copy of the detection script | |
- name: Preserve the detection script | |
run: cp .github/scripts/enums_in_models.rb /tmp/enums_in_models.rb | |
# Check-out main | |
- name: Checkout main branch | |
run: git checkout main | |
# Get all previous enum definitions for changed models from main | |
- name: Get previous enum definitions | |
run: | | |
bundle install | |
bundle exec ruby /tmp/enums_in_models.rb enums_after.log >enums_before.log | |
env: | |
DB_HOSTNAME: localhost | |
DB_USERNAME: postgres | |
DB_PASSWORD: password | |
DB_PORT: 5432 | |
# Diff definitions before and after | |
- name: Check for changed enums | |
run: diff enums_before.log enums_after.log >changed_enums.log || echo 'Enum changes!' | |
# Capture changed_enums.log | |
- name: Capture changed enums | |
id: changed-enums | |
run: | | |
MULTILINE=$(cat changed_enums.log) | |
MULTILINE="${MULTILINE//'%'/'%25'}" | |
MULTILINE="${MULTILINE//$'\n'/'%0A'}" | |
MULTILINE="${MULTILINE//$'\r'/'%0D'}" | |
echo $MULTILINE | |
echo "data<<$GITHUB_SHA" >> $GITHUB_OUTPUT | |
cat changed_enums.log >> $GITHUB_OUTPUT | |
echo "$GITHUB_SHA" >> $GITHUB_OUTPUT | |
shell: bash | |
# Comment on the PR if enums have changed | |
- name: Comment on PR if enums have changed | |
if: contains(steps.changed-enums.outputs.data, 'enum') | |
uses: mshick/add-pr-comment@v2 | |
with: | |
message: | | |
**Database-level enum changes detected** | |
Please include a data migration for these attributes and values: | |
``` | |
${{ steps.changed-enums.outputs.data }} | |
``` | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |