Skip to content

Commit

Permalink
feat: add github workflow to check migrations
Browse files Browse the repository at this point in the history
  • Loading branch information
muhammad-ammar committed Jul 18, 2024
1 parent 5ef321c commit 73e5b6b
Show file tree
Hide file tree
Showing 6 changed files with 152 additions and 16 deletions.
76 changes: 76 additions & 0 deletions .github/workflows/mysql8-migrations.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
name: Migrations check on mysql8

on:
workflow_dispatch:
pull_request:
push:
branches:
- master

jobs:
check_migrations:
name: check migrations
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ ubuntu-20.04 ]
python-version: [ 3.8 ]

steps:
- name: Checkout repo
uses: actions/checkout@v2

- name: Setup Python ${{ matrix.python-version }}
uses: actions/setup-python@v2
with:
python-version: ${{ matrix.python-version }}

- name: Install system Packages
run: |
sudo apt-get update
- name: Get pip cache dir
id: pip-cache-dir
run: |
echo "::set-output name=dir::$(pip cache dir)"
- name: Cache pip dependencies
id: cache-dependencies
uses: actions/cache@v2
with:
path: ${{ steps.pip-cache-dir.outputs.dir }}
key: ${{ runner.os }}-pip-${{ hashFiles('requirements/pip_tools.txt') }}
restore-keys: ${{ runner.os }}-pip-

- name: Ubuntu and sql Versions
run: |
lsb_release -a
mysql -V
- name: Install Python dependencies
run: |
pip install -r requirements/dev.txt
pip uninstall -y mysqlclient
pip install --no-binary mysqlclient mysqlclient
- name: Initiate Services
run: |
sudo /etc/init.d/mysql start
- name: Reset mysql password
run: |
cat <<EOF | mysql -h 127.0.0.1 -u root --password=root
UPDATE mysql.user SET authentication_string = null WHERE user = 'root';
FLUSH PRIVILEGES;
EOF
- name: Run migrations
env:
DATABASES: default
DB_ENGINE: django.db.backends.mysql
DB_USER: root
DB_PASSWORD: ""
DB_HOST: localhost
DB_PORT: 3306
run: |
echo "Running the migrations."
for db in $DATABASES;
do
echo "CREATE DATABASE IF NOT EXISTS db_$db;" | sudo mysql -u root
export DB_NAME=db_$db
python manage.py migrate --noinput --run-syncdb --database "$db" --settings=enterprise_data.settings.test
done
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Generated by Django 3.2.23 on 2024-07-12 07:40
# Generated by Django 3.2.23 on 2024-07-18 05:36

from django.db import migrations, models

Expand Down Expand Up @@ -30,16 +30,11 @@ class Migration(migrations.Migration):
migrations.AddField(
model_name='enterpriselearnerenrollment',
name='lpr_unique_id',
field=models.PositiveBigIntegerField(default=enterprise_data.utils.get_unique_id, primary_key=True, serialize=False),
field=models.PositiveBigIntegerField(default=enterprise_data.utils.get_unique_id, unique=True),
),
migrations.AddField(
model_name='enterpriselearnerenrollment',
name='subscription_license_uuid',
field=models.UUIDField(null=True),
),
migrations.AlterField(
model_name='enterpriselearnerenrollment',
name='enterprise_enrollment_id',
field=models.PositiveIntegerField(null=True),
),
]
24 changes: 24 additions & 0 deletions enterprise_data/migrations/0041_auto_20240718_0545.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Generated by Django 3.2.23 on 2024-07-18 05:45

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('enterprise_data', '0040_auto_20240718_0536'),
]

operations = [
migrations.AlterField(
model_name='enterpriselearnerenrollment',
name='enterprise_enrollment_id',
field=models.PositiveIntegerField(unique=True),
),
migrations.AddField(
model_name='enterpriselearnerenrollment',
name='id',
field=models.AutoField(auto_created=True, default=None, primary_key=True, serialize=False, verbose_name='ID'),
preserve_default=False,
),
]
24 changes: 24 additions & 0 deletions enterprise_data/migrations/0042_auto_20240718_0548.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Generated by Django 3.2.23 on 2024-07-18 05:48

from django.db import migrations, models

import enterprise_data.utils


class Migration(migrations.Migration):

dependencies = [
('enterprise_data', '0041_auto_20240718_0545'),
]

operations = [
migrations.RemoveField(
model_name='enterpriselearnerenrollment',
name='id',
),
migrations.AlterField(
model_name='enterpriselearnerenrollment',
name='lpr_unique_id',
field=models.PositiveBigIntegerField(default=enterprise_data.utils.get_unique_id, primary_key=True, serialize=False),
),
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 3.2.23 on 2024-07-18 06:36

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('enterprise_data', '0042_auto_20240718_0548'),
]

operations = [
migrations.AlterField(
model_name='enterpriselearnerenrollment',
name='enterprise_enrollment_id',
field=models.PositiveIntegerField(null=True),
),
]
17 changes: 8 additions & 9 deletions enterprise_data/settings/test.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,7 @@
In a real-world use case, apps in this project are installed into other
Django applications, so these settings will not be used.
"""


import os
from os.path import abspath, dirname, join

from enterprise_data_roles.constants import (
Expand All @@ -31,13 +30,13 @@ def root(*args):

DATABASES = {
"default": {
"ENGINE": "django.db.backends.sqlite3",
"NAME": "default.db",
"USER": "",
"PASSWORD": "",
"HOST": "",
"PORT": "",
}
"ENGINE": os.environ.get("DB_ENGINE", "django.db.backends.sqlite3"),
"NAME": os.environ.get("DB_NAME", "default.db"),
"USER": os.environ.get("DB_USER", ""),
"PASSWORD": os.environ.get("DB_PASS", ""),
"HOST": os.environ.get("DB_HOST", ""),
"PORT": os.environ.get("DB_PORT", ""),
},
}

INSTALLED_APPS = (
Expand Down

0 comments on commit 73e5b6b

Please sign in to comment.