239 lines
8.6 KiB
YAML
239 lines
8.6 KiB
YAML
|
# 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)
|
||
|
|
||
|
# Remove VMM domain
|
||
|
- name: Remove VMM domain (normal mode)
|
||
|
aci_domain: &domain_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") }}'
|
||
|
domain: vmm_dom
|
||
|
domain_type: vmm
|
||
|
vm_provider: vmware
|
||
|
state: absent
|
||
|
register: nm_remove_domain
|
||
|
|
||
|
# ADD VMM domain for testing
|
||
|
- name: Add VMM domain (normal mode)
|
||
|
aci_domain: &domain_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") }}'
|
||
|
domain: vmm_dom
|
||
|
domain_type: vmm
|
||
|
vm_provider: vmware
|
||
|
state: present
|
||
|
register: nm_add_domain
|
||
|
|
||
|
- name: Verify add_domain
|
||
|
assert:
|
||
|
that:
|
||
|
- nm_add_domain is changed
|
||
|
|
||
|
# REMOVE credential
|
||
|
- name: Remove credential (check mode)
|
||
|
aci_vmm_credential: &credential_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") }}'
|
||
|
name: vmm_cred
|
||
|
description: my_new_cred
|
||
|
domain: vmm_dom
|
||
|
credential_username: myUsername
|
||
|
credential_password: mySecretPassword
|
||
|
vm_provider: vmware
|
||
|
state: absent
|
||
|
check_mode: yes
|
||
|
register: cm_remove_credential
|
||
|
|
||
|
- name: Remove vmware VMM credential (normal mode)
|
||
|
aci_vmm_credential: *credential_absent
|
||
|
register: nm_remove_credential
|
||
|
|
||
|
- name: Verify remove_credential
|
||
|
assert:
|
||
|
that:
|
||
|
- cm_remove_credential is not changed
|
||
|
- nm_remove_credential is not changed
|
||
|
|
||
|
# ADD credential
|
||
|
- name: Add vmware VMM credential (check mode)
|
||
|
aci_vmm_credential: &credential_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") }}'
|
||
|
name: vmm_cred
|
||
|
description: my_new_cred
|
||
|
domain: vmm_dom
|
||
|
credential_username: myUsername
|
||
|
credential_password: mySecretPassword
|
||
|
vm_provider: vmware
|
||
|
state: present
|
||
|
check_mode: yes
|
||
|
register: cm_add_credential
|
||
|
|
||
|
# NOTE: Setting password is not idempotent
|
||
|
- name: Add vmware VMM credential (normal mode)
|
||
|
aci_vmm_credential: *credential_present
|
||
|
register: nm_add_credential
|
||
|
|
||
|
# NOTE: Setting password is not idempotent
|
||
|
- name: Add vmware VMM credential again (check mode)
|
||
|
aci_vmm_credential: *credential_present
|
||
|
check_mode: yes
|
||
|
register: cm_add_credential_again
|
||
|
|
||
|
- name: Verify add_credential
|
||
|
assert:
|
||
|
that:
|
||
|
- cm_add_credential is changed
|
||
|
- nm_add_credential is changed
|
||
|
- 'cm_add_credential.sent == nm_add_credential.sent == {"vmmUsrAccP": {"attributes": {"descr": "my_new_cred", "name": "vmm_cred", "pwd": "mySecretPassword", "usr": "myUsername"}}}'
|
||
|
- 'cm_add_credential.proposed == nm_add_credential.proposed == {"vmmUsrAccP": {"attributes": {"descr": "my_new_cred", "name": "vmm_cred", "pwd": "mySecretPassword", "usr": "myUsername"}}}'
|
||
|
- cm_add_credential.current == cm_add_credential.previous == nm_add_credential.previous == []
|
||
|
- nm_add_credential.current.0.vmmUsrAccP.attributes.dn == 'uni/vmmp-VMware/dom-vmm_dom/usracc-vmm_cred'
|
||
|
- nm_add_credential.current.0.vmmUsrAccP.attributes.name == 'vmm_cred'
|
||
|
|
||
|
# MODIFY credential
|
||
|
- name: Modify vmware VMM credential (check mode)
|
||
|
aci_vmm_credential: &credential_mod
|
||
|
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") }}'
|
||
|
name: vmm_cred
|
||
|
description: my_updated_descr
|
||
|
domain: vmm_dom
|
||
|
credential_username: myNewUsername
|
||
|
credential_password: myNewSecretPassword
|
||
|
vm_provider: vmware
|
||
|
state: present
|
||
|
check_mode: yes
|
||
|
register: cm_mod_credential
|
||
|
|
||
|
- name: Modify vmware VMM credential (normal mode)
|
||
|
aci_vmm_credential: *credential_mod
|
||
|
register: nm_mod_credential
|
||
|
|
||
|
- name: Verify mod_credential
|
||
|
assert:
|
||
|
that:
|
||
|
- cm_mod_credential is changed
|
||
|
- nm_mod_credential is changed
|
||
|
- 'cm_mod_credential.sent == nm_mod_credential.sent == {"vmmUsrAccP": {"attributes": {"descr": "my_updated_descr", "pwd": "myNewSecretPassword", "usr": "myNewUsername"}}}'
|
||
|
- 'cm_mod_credential.proposed == nm_mod_credential.proposed == {"vmmUsrAccP": {"attributes": {"descr": "my_updated_descr", "name": "vmm_cred", "pwd": "myNewSecretPassword", "usr": "myNewUsername"}}}'
|
||
|
- nm_mod_credential.current.0.vmmUsrAccP.attributes.dn == 'uni/vmmp-VMware/dom-vmm_dom/usracc-vmm_cred'
|
||
|
- nm_mod_credential.current.0.vmmUsrAccP.attributes.name == 'vmm_cred'
|
||
|
|
||
|
- name: Query existing vmware VMM credential (check mode)
|
||
|
aci_vmm_credential: &query_existing_cred
|
||
|
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") }}'
|
||
|
name: vmm_cred
|
||
|
domain: vmm_dom
|
||
|
vm_provider: vmware
|
||
|
state: query
|
||
|
check_mode: yes
|
||
|
register: cm_query_credential
|
||
|
|
||
|
- name: Query existing vmware VMM credential (normal mode)
|
||
|
aci_vmm_credential: *query_existing_cred
|
||
|
register: nm_query_credential
|
||
|
|
||
|
- name: Query non-existent vmware VMM credential
|
||
|
aci_vmm_credential:
|
||
|
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") }}'
|
||
|
name: vmm_fake_cred
|
||
|
domain: vmm_dom
|
||
|
vm_provider: vmware
|
||
|
state: query
|
||
|
register: nm_query_fake_credential
|
||
|
|
||
|
- name: Query all vmware VMM credentials (check mode)
|
||
|
aci_vmm_credential: &query_all_creds
|
||
|
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") }}'
|
||
|
vm_provider: vmware
|
||
|
state: query
|
||
|
check_mode: yes
|
||
|
register: cm_query_all_credential
|
||
|
|
||
|
- name: Query all vmware VMM credentials (normal mode)
|
||
|
aci_vmm_credential: *query_all_creds
|
||
|
register: nm_query_all_credential
|
||
|
|
||
|
- name: Verify query_credential
|
||
|
assert:
|
||
|
that:
|
||
|
- cm_query_credential is not changed
|
||
|
- nm_query_credential is not changed
|
||
|
- nm_query_fake_credential is not changed
|
||
|
- cm_query_all_credential is not changed
|
||
|
- nm_query_all_credential is not changed
|
||
|
- cm_query_credential.current.0.vmmUsrAccP.attributes.name == 'vmm_cred'
|
||
|
- nm_query_credential.current.0.vmmUsrAccP.attributes.name == 'vmm_cred'
|
||
|
- nm_query_fake_credential.current == []
|
||
|
- cm_query_all_credential.current.0.vmmUsrAccP.attributes.name == 'vmm_cred'
|
||
|
- nm_query_all_credential.current.0.vmmUsrAccP.attributes.name == 'vmm_cred'
|
||
|
|
||
|
- name: Remove credential (check_mode)
|
||
|
aci_vmm_credential: *credential_absent
|
||
|
check_mode: yes
|
||
|
register: cm_remove_credential_again
|
||
|
|
||
|
- name: Remove credential (normal_mode)
|
||
|
aci_vmm_credential: *credential_absent
|
||
|
register: nm_remove_credential_again
|
||
|
|
||
|
- name: Remove credential (normal_mode)
|
||
|
aci_vmm_credential: *credential_absent
|
||
|
register: nm_remove_credential_final
|
||
|
|
||
|
- name: Verify remove_credential
|
||
|
assert:
|
||
|
that:
|
||
|
- cm_remove_credential_again is changed
|
||
|
- nm_remove_credential_again is changed
|
||
|
- nm_remove_credential_final is not changed
|
||
|
|
||
|
# Remove VMM domain after testing
|
||
|
- name: Remove VMM domain (normal_mode)
|
||
|
aci_domain: *domain_absent
|
||
|
register: nm_remove_domain_again
|