aci_taboo_contract: Add integration tests and examples (#36276)

This PR includes:
- Missing integration tests
- Missing examples
- Two typo's in other integration tests
This commit is contained in:
Dag Wieers 2018-02-16 01:59:23 +01:00 committed by GitHub
parent e1b5bc049c
commit 334e405e6f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 313 additions and 11 deletions

View file

@ -1,6 +1,7 @@
#!/usr/bin/python #!/usr/bin/python
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# Copyright: (c) 2018, Dag Wieers (dagwieers) <dag@wieers.com>
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
from __future__ import absolute_import, division, print_function from __future__ import absolute_import, division, print_function
@ -54,15 +55,40 @@ options:
extends_documentation_fragment: aci extends_documentation_fragment: aci
''' '''
# FIXME: Add more, better examples
EXAMPLES = r''' EXAMPLES = r'''
- aci_taboo_contract: - name: Add taboo contract
host: '{{ inventory_hostname }}' aci_taboo_contract:
username: '{{ username }}' host: '{{ aci_hostname }}'
password: '{{ password }}' username: '{{ aci_username }}'
taboo_contract: '{{ taboo_contract }}' password: '{{ aci_password }}'
description: '{{ descr }}' tenant: ansible_test
tenant: '{{ tenant }}' taboo_contract: taboo_contract_test
state: present
- name: Remove taboo contract
aci_taboo_contract:
host: '{{ aci_hostname }}'
username: '{{ aci_username }}'
password: '{{ aci_password }}'
tenant: ansible_test
taboo_contract: taboo_contract_test
state: absent
- name: Query all taboo contracts
aci_taboo_contract:
host: '{{ aci_hostname }}'
username: '{{ aci_username }}'
password: '{{ aci_password }}'
state: query
- name: Query a specific taboo contract
aci_taboo_contract:
host: '{{ aci_hostname }}'
username: '{{ aci_username }}'
password: '{{ aci_password }}'
tenant: ansible_test
taboo_contract: taboo_contract_test
state: query
''' '''
RETURN = r''' RETURN = r'''
@ -225,7 +251,8 @@ def main():
aci_class='vzTaboo', aci_class='vzTaboo',
class_config=dict( class_config=dict(
name=taboo_contract, name=taboo_contract,
descr=description, scope=scope, descr=description,
scope=scope,
), ),
) )

View file

@ -0,0 +1,275 @@
# Test code for the ACI modules
# Copyright: (c) 2018, Dag Wieers (dagwieers) <dag@wieers.com>
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
# CLEAN ENVIRONMENT
- name: Remove taboo contract
aci_taboo_contract: &taboo_contract_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: info
tenant: ansible_test
taboo_contract: taboo_contract_test
state: absent
- name: Add tenant
aci_tenant:
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: info
tenant: ansible_test
state: present
# ADD TABOO CONTRACT
- name: Add taboo contract (check_mode)
aci_taboo_contract: &taboo_contract_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: info
tenant: ansible_test
taboo_contract: taboo_contract_test
state: present
check_mode: yes
register: cm_add_taboo_contract
- name: Add taboo contract (normal mode)
aci_taboo_contract: *taboo_contract_present
register: nm_add_taboo_contract
- name: Verify add_taboo_contract
assert:
that:
- cm_add_taboo_contract.changed == nm_add_taboo_contract.changed == true
- 'cm_add_taboo_contract.sent == nm_add_taboo_contract.sent == {"vzTaboo": {"attributes": {"name": "taboo_contract_test"}}}'
- 'cm_add_taboo_contract.proposed == nm_add_taboo_contract.proposed == {"vzTaboo": {"attributes": {"name": "taboo_contract_test"}}}'
- cm_add_taboo_contract.previous == nm_add_taboo_contract.previous == []
# NOTE: We cannot fix this easily
- cm_add_taboo_contract.current == []
- nm_add_taboo_contract.current.0.vzTaboo.attributes.descr == ''
- nm_add_taboo_contract.current.0.vzTaboo.attributes.dn == 'uni/tn-ansible_test/taboo-taboo_contract_test'
- nm_add_taboo_contract.current.0.vzTaboo.attributes.name == 'taboo_contract_test'
- name: Add taboo_contract again (check_mode)
aci_taboo_contract: *taboo_contract_present
check_mode: yes
register: cm_add_taboo_contract_again
- name: Add taboo contract again (normal mode)
aci_taboo_contract: *taboo_contract_present
register: nm_add_taboo_contract_again
- name: Verify add_taboo_contract_again
assert:
that:
- cm_add_taboo_contract_again.changed == nm_add_taboo_contract_again.changed == false
- cm_add_taboo_contract_again.current == nm_add_taboo_contract_again.current == nm_add_taboo_contract.current
# CHANGE TABOO CONTRACT
- name: Change description of taboo contract (check_mode)
aci_taboo_contract:
<<: *taboo_contract_present
description: Ansible test taboo contract
check_mode: yes
register: cm_add_taboo_contract_descr
- name: Change description of taboo contract (normal mode)
aci_taboo_contract:
<<: *taboo_contract_present
description: Ansible test taboo contract
register: nm_add_taboo_contract_descr
- name: Verify add_taboo_contract_descr
assert:
that:
- cm_add_taboo_contract_descr.changed == nm_add_taboo_contract_descr.changed == true
- 'cm_add_taboo_contract_descr.sent == nm_add_taboo_contract_descr.sent == {"vzTaboo": {"attributes": {"descr": "Ansible test taboo contract"}}}'
- 'cm_add_taboo_contract_descr.proposed == nm_add_taboo_contract_descr.proposed == {"vzTaboo": {"attributes": {"descr": "Ansible test taboo contract", "name": "taboo_contract_test"}}}'
- cm_add_taboo_contract_descr.previous == nm_add_taboo_contract_descr.previous == cm_add_taboo_contract_descr.current == nm_add_taboo_contract.current
- nm_add_taboo_contract_descr.current.0.vzTaboo.attributes.descr == 'Ansible test taboo contract'
- nm_add_taboo_contract_descr.current.0.vzTaboo.attributes.dn == 'uni/tn-ansible_test/taboo-taboo_contract_test'
- nm_add_taboo_contract_descr.current.0.vzTaboo.attributes.name == 'taboo_contract_test'
- name: Change description of taboo contract again (check_mode)
aci_taboo_contract:
<<: *taboo_contract_present
description: Ansible test taboo contract
check_mode: yes
register: cm_add_taboo_contract_descr_again
- name: Change description of taboo contract again (normal mode)
aci_taboo_contract:
<<: *taboo_contract_present
description: Ansible test taboo contract
register: nm_add_taboo_contract_descr_again
- name: Verify add_taboo_contract_descr_again
assert:
that:
- cm_add_taboo_contract_descr_again.changed == nm_add_taboo_contract_descr_again.changed == false
- cm_add_taboo_contract_descr_again.current == nm_add_taboo_contract_descr_again.current == nm_add_taboo_contract_descr.current
# ADD TABOO CONTRACT AGAIN
- name: Add taboo contract again with no description (check_mode)
aci_taboo_contract: *taboo_contract_present
check_mode: yes
register: cm_add_taboo_contract_again_no_descr
- name: Add taboo contract again with no description (normal mode)
aci_taboo_contract: *taboo_contract_present
register: nm_add_taboo_contract_again_no_descr
- name: Verify add_taboo_contract_again_no_descr
assert:
that:
- cm_add_taboo_contract_again_no_descr.changed == nm_add_taboo_contract_again_no_descr.changed == false
- cm_add_taboo_contract_again_no_descr.current == nm_add_taboo_contract_again_no_descr.current == nm_add_taboo_contract_descr.current
# QUERY ALL TABOO CONTRACTS
- name: Query all taboo contracts (check_mode)
aci_taboo_contract: &taboo_contract_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) }}'
state: query
check_mode: yes
register: cm_query_all_taboo_contracts
- name: Query all taboo contracts (normal mode)
aci_taboo_contract: *taboo_contract_query
register: nm_query_all_taboo_contracts
- name: Verify query_all_taboo_contracts
assert:
that:
- cm_query_all_taboo_contracts.changed == nm_query_all_taboo_contracts.changed == false
- cm_query_all_taboo_contracts == nm_query_all_taboo_contracts
- cm_query_all_taboo_contracts.current|length >= 1
# QUERY A TABOO CONTRACT
- name: Query our taboo contract
aci_taboo_contract:
<<: *taboo_contract_query
tenant: ansible_test
taboo_contract: taboo_contract_test
check_mode: yes
register: cm_query_taboo_contract
- name: Query our taboo contract
aci_taboo_contract:
<<: *taboo_contract_query
tenant: ansible_test
taboo_contract: taboo_contract_test
register: nm_query_taboo_contract
- name: Verify query_taboo_contract
assert:
that:
- cm_query_taboo_contract.changed == nm_query_taboo_contract.changed == false
- cm_query_taboo_contract == nm_query_taboo_contract
- nm_query_taboo_contract.current.0.vzTaboo.attributes.descr == 'Ansible test taboo contract'
- nm_query_taboo_contract.current.0.vzTaboo.attributes.dn == 'uni/tn-ansible_test/taboo-taboo_contract_test'
- nm_query_taboo_contract.current.0.vzTaboo.attributes.name == 'taboo_contract_test'
# REMOVE TABOO CONTRACT
- name: Remove taboo contract (check_mode)
aci_taboo_contract: *taboo_contract_absent
check_mode: yes
register: cm_remove_taboo_contract
- name: Remove taboo contract (normal mode)
aci_taboo_contract: *taboo_contract_absent
register: nm_remove_taboo_contract
- name: Verify remove_taboo_contract
assert:
that:
- cm_remove_taboo_contract.changed == nm_remove_taboo_contract.changed == true
- 'cm_remove_taboo_contract.current == cm_remove_taboo_contract.previous == nm_remove_taboo_contract.previous == [{"vzTaboo": {"attributes": {"descr": "Ansible test taboo contract", "dn": "uni/tn-ansible_test/taboo-taboo_contract_test", "name": "taboo_contract_test", "nameAlias": "", "ownerKey": "", "ownerTag": ""}}}]'
- nm_remove_taboo_contract.current == []
- name: Remove taboo contract again (check_mode)
aci_taboo_contract: *taboo_contract_absent
check_mode: yes
register: cm_remove_taboo_contract_again
- name: Remove taboo contract again (normal mode)
aci_taboo_contract: *taboo_contract_absent
register: nm_remove_taboo_contract_again
- name: Verify remove_taboo_contract_again
assert:
that:
- cm_remove_taboo_contract_again.changed == nm_remove_taboo_contract_again.changed == false
- cm_remove_taboo_contract_again.proposed == nm_remove_taboo_contract_again.proposed == {}
- cm_remove_taboo_contract_again.sent == nm_remove_taboo_contract_again.sent == {}
- cm_remove_taboo_contract_again.previous == nm_remove_taboo_contract_again.previous == []
- cm_remove_taboo_contract_again.current == nm_remove_taboo_contract_again.current == []
# QUERY NON-EXISTING TABOO CONTRACT
- name: Query non-existing taboo contract (check_mode)
aci_taboo_contract:
<<: *taboo_contract_query
tenant: ansible_test
taboo_contract: taboo_contract_test
check_mode: yes
register: cm_query_non_taboo_contract
- name: Query non-existing taboo contract (normal mode)
aci_taboo_contract:
<<: *taboo_contract_query
tenant: ansible_test
taboo_contract: taboo_contract_test
register: nm_query_non_taboo_contract
# TODO: Implement more tests
- name: Verify query_non_taboo_contract
assert:
that:
- cm_query_non_taboo_contract.changed == nm_query_non_taboo_contract.changed == false
- cm_remove_taboo_contract_again.previous == nm_remove_taboo_contract_again.previous == []
- cm_remove_taboo_contract_again.current == nm_remove_taboo_contract_again.current == []
# PROVOKE ERRORS
- name: Error when required parameter is missing
aci_taboo_contract:
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: info
state: present
ignore_errors: yes
register: error_on_missing_required_param
- name: Assertion test - present
assert:
that:
- error_on_missing_required_param.failed == true
- 'error_on_missing_required_param.msg == "state is present but all of the following are missing: tenant, taboo_contract"'

View file

@ -165,7 +165,7 @@
check_mode: yes check_mode: yes
register: cm_query_dynamic_vlan_pool register: cm_query_dynamic_vlan_pool
- name: Query ourdynamic vlan pool - name: Query our dynamic vlan pool
aci_vlan_pool: aci_vlan_pool:
<<: *dynamic_vlan_pool_query <<: *dynamic_vlan_pool_query
pool: anstest pool: anstest

View file

@ -165,7 +165,7 @@
check_mode: yes check_mode: yes
register: cm_query_static_vlan_pool register: cm_query_static_vlan_pool
- name: Query ourstatic vlan pool - name: Query our static vlan pool
aci_vlan_pool: aci_vlan_pool:
<<: *static_vlan_pool_query <<: *static_vlan_pool_query
pool: anstest pool: anstest