-
Notifications
You must be signed in to change notification settings - Fork 46
60 lines (60 loc) · 2.56 KB
/
pr.yaml
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
name: "Build"
on:
- pull_request
jobs:
validate-format:
name: Validate Format
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Install JDK
uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: 17
check-latest: true
cache: 'gradle'
- name: Format
run: ./gradlew spotlessCheck checkstyleMain checkstyleTest
validate-floorplan-queries:
name: Validate FloorPlan Queries
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Setup GIT config
run: |
git config --global user.name "$(git --no-pager log --format=format:'%an' -n 1)"
git config --global user.email "$(git --no-pager log --format=format:'%ae' -n 1)"
- name: Install JDK
uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: 17
check-latest: true
cache: 'gradle'
- name: Setup JBang
uses: jbangdev/setup-jbang@main
- name: Setup yamlpath
run: |
jbang trust add https://github.com/yaml-path/jbang/
curl -Ls https://sh.jbang.dev | bash -s - app install --fresh --force yamlpath@yaml-path/jbang
- name: Setup Postgresql Database
run: docker run -d -v ./init_dbs.sh:/usr/share/container-scripts/postgresql/start/set_passwords.sh:z -p 5432:5432 -e POSTGRESQL_ADMIN_PASSWORD=admin quay.io/centos7/postgresql-12-centos7:centos7
- name: Setup Postgresql Client
run: sudo apt-get install -y postgresql-client
- name: Execute migrations
run: ./gradlew :liquibaseUpdate
- name: Run validation
run: |
QUERY_NAMES=$(yamlpath --format=PLAIN --single --expression="objects.(kind==FloorPlan).spec.queries.prefix" swatch-tally/deploy/clowdapp.yaml | tail -c +2 | head -c -2)
for rawQueryName in ${QUERY_NAMES[*]}; do
queryName=$(echo $rawQueryName | sed 's/,//g')
query=$(yamlpath --format=PLAIN --single --expression="objects.(kind==FloorPlan).spec.queries.(prefix == $queryName).query" swatch-tally/deploy/clowdapp.yaml | sed 's/;//g')
echo -e "Validating query: \n$query\n"
output=$(PGPASSWORD=rhsm-subscriptions psql -h localhost -U rhsm-subscriptions -d rhsm-subscriptions -c "$query;")
if [[ "$output" != *"(0 rows)"* ]]; then
echo -e "Error in query. Check the output for more information: \n$output"
exit 1
fi
done
echo "Queries validation was successful"