-
Notifications
You must be signed in to change notification settings - Fork 50
104 lines (103 loc) · 3.61 KB
/
build_database.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
name: Build Databases
on:
push:
branches-ignore:
- 'master'
jobs:
# build_database_mysql:
# runs-on: ubuntu-20.04
# services:
# mysql:
# # 8 is chosen because that matches the version of the client utils we will install
# image: mysql:8.0
# env:
# MYSQL_ROOT_PASSWORD: 1234
# ports:
# - 3306:3306/tcp
# options: >-
# --health-cmd "/usr/bin/mysql -h 127.0.0.1 --user=root --password=1234 --execute \"SHOW DATABASES;\""
# --health-interval 5s
# --health-timeout 5s
# --health-retries 20
# steps:
# - uses: actions/checkout@v2
# - name: Setup python
# uses: actions/setup-python@v2
# with:
# python-version: 3.9
# architecture: x64
# # we also need mysql-client-8.0 BUT it is installed my default
# # and if we explicitly ask for it to be safe we sometimes get package errors
# - name: Install Ubuntu libs
# run: sudo apt-get install -y graphviz graphviz-dev
# - name: Install Python libs
# run: pip install -r requirements.txt
# - name: Install Python Libs for DB work
# run: pip install -r requirements_build_database.in
# - run: MYSQL_ROOT_PASSWORD=1234 ./build_database_mysql.sh
# - run: cat database/database_mysql.sql
# - name: Check for changes
# run: |
# if git diff --exit-code; then
# echo "CHANGED=false" >>${GITHUB_ENV}
# else
# echo "CHANGED=true" >>${GITHUB_ENV}
# fi
# - name: Commit database back (if changes)
# if: env.CHANGED == 'true'
# run: |
# git config --global user.name 'Database Schema Generator'
# git config --global user.email 'hello@openreferral.org'
# git add database/database_mysql.sql
# git commit -m "Mysql Database Schema changed by automatic generation" database/database_mysql.sql
# git push
build_database_postgresql:
#needs: build_database_mysql
runs-on: ubuntu-20.04
services:
postgresql:
# 12 is chosen because that matches the version of the client utils we will install
image: postgres:12
env:
POSTGRES_PASSWORD: 1234
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 5432:5432/tcp
steps:
- uses: actions/checkout@v2
- name: Setup python
uses: actions/setup-python@v2
with:
python-version: 3.9
architecture: x64
# If the MySQL stage above made changes, we need to pull first
- run: git pull
- name: Install Ubuntu libs
run: |
sudo apt-get update
sudo apt-get install -y graphviz graphviz-dev postgresql-client-12 libpq-dev
- name: Install Python libs
run: pip install -r requirements.txt
- name: Install Python Libs for DB work
run: pip install -r requirements_build_database.in
- run: POSTGRESQL_PASSWORD=1234 ./build_database_postgresql.sh
- run: cat database/database_postgresql.sql
- name: Check for changes
run: |
if git diff --exit-code; then
echo "CHANGED=false" >>${GITHUB_ENV}
else
echo "CHANGED=true" >>${GITHUB_ENV}
fi
- name: Commit database back (if changes)
if: env.CHANGED == 'true'
run: |
git config --global user.name 'Database Schema Generator'
git config --global user.email 'hello@openreferral.org'
git add database/database_postgresql.sql
git commit -m "Postgresql Database Schema changed by automatic generation" database/database_postgresql.sql
git push