Skip to content

Merge pull request #4572 from wastaken7/master #12

Merge pull request #4572 from wastaken7/master

Merge pull request #4572 from wastaken7/master #12

Workflow file for this run

name: MySQL Schema Dump (Laravel)
on: [ push, pull_request ]
jobs:
schema-dump:
strategy:
matrix:
operating-system:
- ubuntu-22.04
php-version:
- '8.4'
name: php ${{ matrix.php-version }} on ${{ matrix.operating-system }}
runs-on: ${{ matrix.operating-system }}
services:
mysql:
image: mysql:8.0
env:
MYSQL_ALLOW_EMPTY_PASSWORD: yes
MYSQL_DATABASE: unit3d
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3
redis:
image: redis:7.2.1
ports:
- 6379:6379
options: >-
--health-cmd "redis-cli ping"
--health-interval 10s
--health-timeout 5s
--health-retries 5
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup PHP 8.4
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php-version }}
extensions: curl, dom, gd, libxml, mbstring, zip, mysql, xml, intl, bcmath, redis-phpredis/phpredis@6.0.1
ini-values: error_reporting=E_ALL
coverage: none
tools: composer:v2
env:
REDIS_CONFIGURE_OPTS: --enable-redis
- name: Install Composer Dependencies
env:
COMPOSER_AUTH: ${{ secrets.COMPOSER_AUTH }}
run: composer install --no-ansi --no-interaction --no-scripts --no-progress --prefer-dist
- name: Prepare The Laravel Environment
run: cp .env.example .env
- name: Generate Application Key
run: php artisan key:generate
- name: Clear Application Cache
run: php artisan optimize:clear
- name: Run Migrations
run: php artisan migrate --force
env:
DB_CONNECTION: mysql
DB_HOST: 127.0.0.1
DB_PORT: ${{ job.services.mysql.ports['3306'] }}
DB_DATABASE: unit3d
DB_USERNAME: root
DB_PASSWORD: null
- name: Run Schema Dump
run: php artisan schema:dump --path=database/schema/mysql-schema-new.sql
env:
DB_CONNECTION: mysql
DB_HOST: 127.0.0.1
DB_PORT: ${{ job.services.mysql.ports['3306'] }}
DB_DATABASE: unit3d
DB_USERNAME: root
DB_PASSWORD: null
- name: Check if schema has changed
id: diff
run: |
if [ -f database/schema/mysql-schema.sql ] && diff -q database/schema/mysql-schema.sql database/schema/mysql-schema-new.sql > /dev/null; then
echo "No changes detected in schema"
echo "has_changes=false" >> $GITHUB_OUTPUT
else
echo "Changes detected in schema"
echo "has_changes=true" >> $GITHUB_OUTPUT
fi
- name: Update Schema
if: steps.diff.outputs.has_changes == 'true'
run: |
cp database/schema/mysql-schema-new.sql database/schema/mysql-schema.sql
rm database/schema/mysql-schema-new.sql
- name: Commit Schema Changes
if: steps.diff.outputs.has_changes == 'true'
uses: stefanzweifel/git-auto-commit-action@v5
with:
commit_message: "automation: update schema dump"
commit_user_name: unit3d-bot
commit_user_email: unit3d_gh_bot@protonmail.com
commit_author: unit3d-bot <unit3d_gh_bot@protonmail.com>