-
Notifications
You must be signed in to change notification settings - Fork 11
72 lines (57 loc) · 2.44 KB
/
ci_test_ud_db.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
name: CI Test UD database
on:
push:
branches: [dev-3.6, dev-4.0]
pull_request:
branches: [dev-3.6, dev-4.0]
jobs:
ci_test_ud_db:
runs-on: ubuntu-latest
env:
PGPASSWORD: postgres
steps:
- name: Checkout repository
uses: actions/checkout@v2
- name: Set up Python
uses: actions/setup-python@v2
with:
python-version: "3.x"
- name: Install Python dependencies
run: |
python -m pip install --upgrade pip
pip install -r test/requirements.txt
- name: Add PostgreSQL repository
run: |
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
wget -qO - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
- name: Update apt-get and Install PostgreSQL, PostGIS, pgRouting, and pgTAP
run: |
sudo apt-get update
sudo apt-get install -y postgresql-16 postgresql-16-postgis-3 postgresql-16-pgrouting postgresql-16-pgtap postgis
- name: Start PostgreSQL service
run: |
sudo service postgresql start
sudo -u postgres psql -c "ALTER USER postgres PASSWORD 'postgres';"
- name: Create PostgreSQL Database
run: |
psql -h localhost -U postgres -c 'CREATE DATABASE gw_db;'
- name: Setup PostgreSQL extensions
run: |
psql -h localhost -U postgres -d gw_db -c 'CREATE EXTENSION postgis;'
psql -h localhost -U postgres -d gw_db -c 'CREATE EXTENSION pgrouting;'
psql -h localhost -U postgres -d gw_db -c 'CREATE EXTENSION postgis_raster;'
psql -h localhost -U postgres -d gw_db -c 'CREATE EXTENSION postgis_topology;'
psql -h localhost -U postgres -d gw_db -c 'CREATE EXTENSION pgtap;'
- name: Replace variables in SQL files
run: python test/replace_vars.py ud
- name: Create Sample Schema
run: python test/execute_sql_files.py ud
- name: Run SQL Tests with pgTAP and pg_prove (PL/SQL)
run: |
pg_prove -h localhost -U postgres -d gw_db test/plsql/ud/*.sql
- name: Run SQL Tests with pgTAP and pg_prove (UPSERT)
run: |
pg_prove -h localhost -U postgres -d gw_db test/upsert/ud/*.sql
- name: Run SQL Tests with pgTAP and pg_prove (STRUCTURE)
run: |
pg_prove -h localhost -U postgres -d gw_db test/structure/ud/*.sql