summaryrefslogtreecommitdiffstats
path: root/test/integration/targets/aci_tenant/tasks/main.yml
blob: 18ad043b0b44086c5034acf87e755d0f91fae6f1 (plain)
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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
# Test code for the ACI modules
# Copyright: (c) 2017, Dag Wieers (@dagwieers) <dag@wieers.com>

# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)

- name: Test that we have an ACI APIC host, ACI username and ACI password
  fail:
    msg: 'Please define the following variables: aci_hostname, aci_username and aci_password.'
  when: aci_hostname is not defined or aci_username is not defined or aci_password is not defined


# CLEAN ENVIRONMENT
- name: Remove tenant
  aci_tenant: &tenant_absent
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    tenant: ansible_test
    state: absent


# ADD TENANT
- name: Add tenant (check_mode)
  aci_tenant: &tenant_present
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    tenant: ansible_test
    state: present
  check_mode: yes
  register: cm_add_tenant

- name: Add tenant (normal mode)
  aci_tenant: *tenant_present
  register: nm_add_tenant

- name: Add tenant again (check_mode)
  aci_tenant: *tenant_present
  check_mode: yes
  register: cm_add_tenant_again

- name: Add tenant again (normal mode)
  aci_tenant: *tenant_present
  register: nm_add_tenant_again

- name: Verify add_tenant
  assert:
    that:
    - cm_add_tenant.changed == nm_add_tenant.changed == true
    - cm_add_tenant_again.changed == nm_add_tenant_again.changed == false


# CHANGE TENANT
- name: Change description of tenant (check_mode)
  aci_tenant:
    <<: *tenant_present
    description: Ansible test tenant
  check_mode: yes
  register: cm_add_tenant_descr

- name: Change description of tenant (normal mode)
  aci_tenant:
    <<: *tenant_present
    description: Ansible test tenant
  register: nm_add_tenant_descr

- name: Change description of tenant again (check_mode)
  aci_tenant:
    <<: *tenant_present
    description: Ansible test tenant
  check_mode: yes
  register: cm_add_tenant_descr_again

- name: Change description of tenant again (normal mode)
  aci_tenant:
    <<: *tenant_present
    description: Ansible test tenant
  register: nm_add_tenant_descr_again

- name: Verify add_tenant_descr
  assert:
    that:
    - cm_add_tenant_descr.changed == nm_add_tenant_descr.changed == true
    - cm_add_tenant_descr_again.changed == nm_add_tenant_descr_again.changed == false


# ADD TENANT AGAIN
- name: Add tenant again with no description (check_mode)
  aci_tenant: *tenant_present
  check_mode: yes
  register: cm_add_tenant_again_no_descr

- name: Add tenant again with no description (normal mode)
  aci_tenant: *tenant_present
  register: nm_add_tenant_again_no_descr

- name: Verify add_tenant_again_no_descr
  assert:
    that:
    - cm_add_tenant_again_no_descr.changed == nm_add_tenant_again_no_descr.changed == false


# QUERY ALL TENANTS
- name: Query all tenants (check_mode)
  aci_tenant: &tenant_query
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    state: query
  check_mode: yes
  register: cm_query_all_tenants

- name: Query all tenants (normal mode)
  aci_tenant: *tenant_query
  register: nm_query_all_tenants

- name: Verify query_all_tenants
  assert:
    that:
    - cm_query_all_tenants.changed == nm_query_all_tenants.changed == false
    # NOTE: Order of tenants is not stable between calls
    #- cm_query_all_tenants == nm_query_all_tenants


# QUERY A TENANT
- name: Query our tenant
  aci_tenant:
    <<: *tenant_query
    tenant: ansible_test
  check_mode: yes
  register: cm_query_tenant

- name: Query our tenant
  aci_tenant:
    <<: *tenant_query
    tenant: ansible_test
  register: nm_query_tenant

- name: Verify query_tenant
  assert:
    that:
    - cm_query_tenant.changed == nm_query_tenant.changed == false
    - cm_query_tenant == nm_query_tenant


# REMOVE TENANT
- name: Remove tenant (check_mode)
  aci_tenant: *tenant_absent
  check_mode: yes
  register: cm_remove_tenant

- name: Remove tenant (normal mode)
  aci_tenant: *tenant_absent
  register: nm_remove_tenant

- name: Remove tenant again (check_mode)
  aci_tenant: *tenant_absent
  check_mode: yes
  register: cm_remove_tenant_again

- name: Remove tenant again (normal mode)
  aci_tenant: *tenant_absent
  register: nm_remove_tenant_again

- name: Verify remove_tenant
  assert:
    that:
    - cm_remove_tenant.changed == nm_remove_tenant.changed == true
    - cm_remove_tenant_again.changed == nm_remove_tenant_again.changed == false


# QUERY NON-EXISTING TENANT
- name: Query non-existing tenant (check_mode)
  aci_tenant:
    <<: *tenant_query
    tenant: ansible_test
  check_mode: yes
  register: cm_query_non_tenant

- name: Query non-existing tenant (normal mode)
  aci_tenant:
    <<: *tenant_query
    tenant: ansible_test
  register: nm_query_non_tenant

# TODO: Implement more tests
- name: Verify query_non_tenant
  assert:
    that:
    - cm_query_non_tenant.changed == nm_query_non_tenant.changed == false
    - cm_query_non_tenant == nm_query_non_tenant