forked from freeipa/ansible-freeipa
-
Notifications
You must be signed in to change notification settings - Fork 0
147 lines (136 loc) · 4.89 KB
/
test_deployment.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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
---
name: Test collection roles
on:
- push
- pull_request
env:
test_path: ".galaxy-build"
jobs:
check_roles:
name: Verify modified roles
runs-on: ubuntu-latest
outputs:
ipaserver: ${{ steps.mod_files.outputs.ipaserver }}
ipareplica: ${{ steps.mod_files.outputs.ipareplica }}
ipaclient: ${{ steps.mod_files.outputs.ipaclient }}
steps:
- uses: actions/[email protected]
with:
fetch-depth: 1
- name: Check modified roles
id: mod_files
shell: bash
run: |
set -eu
git remote add upstream https://github.com/freeipa/ansible-freeipa
git fetch --depth 1 upstream master
git diff -M --name-only upstream/master \
| grep "^roles" \
| cut -d/ -f2 \
| sort | uniq \
| sed "s/\(.*\)/Testing: \1/"
git diff -M --name-only upstream/master \
| grep "^roles" \
| cut -d/ -f2 \
| sort | uniq \
| sed "s/\(.*\)/\1=true/" >> $GITHUB_OUTPUT
test_ipaserver:
name: Test ipaserver role
needs: [check_roles]
if: ${{ needs.check_roles.outputs.ipaserver }}
runs-on: ubuntu-latest
strategy:
matrix:
distro:
- fedora-latest
- c10s
cluster_config:
- ipaserver_test_base.yml
# - ipaserver_ca_dns_nokra_noad.yml
# - ipaserver_ipaclient_ca_only.yml
steps:
- uses: actions/[email protected]
with:
fetch-depth: 1
- name: Build and install collection
run: |
utils/build-galaxy-release.sh -k \
-o "$(curl -L https://api.github.com/repos/freeipa/ansible-freeipa/releases 2>/dev/null \
| jq '.[0].tag_name' | tr -d '"v')-dev$(date +"%Y%m%d%H%M")"
- name: Test ipaserver
uses: rjeffman/[email protected]
with:
cluster_configuration: tests/deployment/${{ matrix.cluster_config }}
# ansible_vars: test/deployment/ipaserver-vars.yml
distro: ${{ matrix.distro }}
test_playbooks: >-
${{ env.test_path }}/tests/user/test_user.yml
${{ env.test_path }}/tests/group/test_group.yml
${{ env.test_path }}/tests/host/test_host.yml
${{ env.test_path }}/tests/hbacrule/test_hbacrule.yml
test_ipareplica:
name: Test ipareplica role
needs: [check_roles]
if: ${{ needs.check_roles.outputs.ipareplica }}
runs-on: ubuntu-latest
strategy:
matrix:
distro:
- fedora-latest
- c10s
# The ipaserver capabilities are "ca-dns-kra"
cluster_config:
- ipareplica_ca.yml
# - ipareplica_none.yml
steps:
- uses: actions/[email protected]
with:
fetch-depth: 1
- name: Build and install collection
run: |
utils/build-galaxy-release.sh -k \
-o "$(curl -L https://api.github.com/repos/freeipa/ansible-freeipa/releases 2>/dev/null \
| jq '.[0].tag_name' | tr -d '"v')-dev$(date +"%Y%m%d%H%M")"
- name: Test ipareplica
uses: rjeffman/[email protected]
with:
cluster_configuration: tests/deployment/${{ matrix.cluster_config }}
ansible_vars: test/deployment/ipareplica-vars.yml
distro: ${{ matrix.distro }}
test_playbooks: >-
${{ env.test_path }}/tests/user/test_user.yml
${{ env.test_path }}/tests/group/test_group.yml
${{ env.test_path }}/tests/host/test_host.yml
${{ env.test_path }}/tests/hbacrule/test_hbacrule.yml
test_ipaclientt:
name: Test ipaclient role
needs: [check_roles]
if: ${{ needs.check_roles.outputs.ipaclient }}
runs-on: ubuntu-latest
strategy:
matrix:
distro:
- fedora-latest
# The ipaserver capabilities are "ca-dns-kra"
cluster_config:
- ipaserver_1_client.yml
steps:
- uses: actions/[email protected]
with:
fetch-depth: 1
- name: Build and install collection
run: |
utils/build-galaxy-release.sh -k \
-o "$(curl -L https://api.github.com/repos/freeipa/ansible-freeipa/releases 2>/dev/null \
| jq '.[0].tag_name' | tr -d '"v')-dev$(date +"%Y%m%d%H%M")"
- name: Test ipaclient
uses: rjeffman/[email protected]
with:
cluster_configuration: tests/deployment/${{ matrix.cluster_config }}
# ansible_vars: test/deployment/ipaclient-vars.yml
distro: ${{ matrix.distro }}
test_playbooks: >-
${{ env.test_path }}/tests/user/test_user_client_context.yml
${{ env.test_path }}/tests/group/test_group_client_context.yml
${{ env.test_path }}/tests/host/test_host_client_context.yml
${{ env.test_path }}/tests/hbacrule/test_hbacrule_client_context.yml