ansible/test/integration/targets/aci_vlan_pool/tasks/static.yml
Dag Wieers 79d00adc52
aci_rest: Fix error handling and improve documentation ()
This PR includes:
- A fix for a recently introduced issue wrt. error handling
- Added integration tests for provoked errors
- Influence standard return values using aci library for aci_rest
- Add proxy support documentation
- Documentation update related to 
2018-02-19 12:01:14 +01:00

285 lines
11 KiB
YAML

# 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 static vlan pool
aci_vlan_pool: &static_vlan_pool_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
pool: anstest
pool_allocation_mode: static
state: absent
# ADD VLAN POOL
- name: Add static vlan pool (check_mode)
aci_vlan_pool: &static_vlan_pool_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
pool: anstest
pool_allocation_mode: static
state: present
check_mode: yes
register: cm_add_static_vlan_pool
- name: Add static vlan pool (normal mode)
aci_vlan_pool: *static_vlan_pool_present
register: nm_add_static_vlan_pool
- name: Verify add_static_vlan_pool
assert:
that:
- cm_add_static_vlan_pool.changed == nm_add_static_vlan_pool.changed == true
- 'cm_add_static_vlan_pool.sent == nm_add_static_vlan_pool.sent == {"fvnsVlanInstP": {"attributes": {"allocMode": "static", "name": "anstest"}}}'
- 'cm_add_static_vlan_pool.proposed == nm_add_static_vlan_pool.proposed == {"fvnsVlanInstP": {"attributes": {"allocMode": "static", "name": "anstest"}}}'
- cm_add_static_vlan_pool.previous == nm_add_static_vlan_pool.previous == []
# NOTE: We cannot fix this easily
- cm_add_static_vlan_pool.current == []
- nm_add_static_vlan_pool.current.0.fvnsVlanInstP.attributes.allocMode == 'static'
- nm_add_static_vlan_pool.current.0.fvnsVlanInstP.attributes.descr == ''
- nm_add_static_vlan_pool.current.0.fvnsVlanInstP.attributes.dn == 'uni/infra/vlanns-[anstest]-static'
- nm_add_static_vlan_pool.current.0.fvnsVlanInstP.attributes.name == 'anstest'
- name: Add static_vlan_pool again (check_mode)
aci_vlan_pool: *static_vlan_pool_present
check_mode: yes
register: cm_add_static_vlan_pool_again
- name: Add static vlan pool again (normal mode)
aci_vlan_pool: *static_vlan_pool_present
register: nm_add_static_vlan_pool_again
- name: Verify add_static_vlan_pool_again
assert:
that:
- cm_add_static_vlan_pool_again.changed == nm_add_static_vlan_pool_again.changed == false
- cm_add_static_vlan_pool_again.current == nm_add_static_vlan_pool_again.current == nm_add_static_vlan_pool.current
# CHANGE VLAN POOL
- name: Change description of static vlan pool (check_mode)
aci_vlan_pool:
<<: *static_vlan_pool_present
description: Ansible test static vlan pool
check_mode: yes
register: cm_add_static_vlan_pool_descr
- name: Change description of static vlan pool (normal mode)
aci_vlan_pool:
<<: *static_vlan_pool_present
description: Ansible test static vlan pool
register: nm_add_static_vlan_pool_descr
- name: Verify add_static_vlan_pool_descr
assert:
that:
- cm_add_static_vlan_pool_descr.changed == nm_add_static_vlan_pool_descr.changed == true
- 'cm_add_static_vlan_pool_descr.sent == nm_add_static_vlan_pool_descr.sent == {"fvnsVlanInstP": {"attributes": {"descr": "Ansible test static vlan pool"}}}'
- 'cm_add_static_vlan_pool_descr.proposed == nm_add_static_vlan_pool_descr.proposed == {"fvnsVlanInstP": {"attributes": {"allocMode": "static", "descr": "Ansible test static vlan pool", "name": "anstest"}}}'
- cm_add_static_vlan_pool_descr.previous == nm_add_static_vlan_pool_descr.previous == cm_add_static_vlan_pool_descr.current == nm_add_static_vlan_pool.current
- nm_add_static_vlan_pool_descr.current.0.fvnsVlanInstP.attributes.allocMode == 'static'
- nm_add_static_vlan_pool_descr.current.0.fvnsVlanInstP.attributes.descr == 'Ansible test static vlan pool'
- nm_add_static_vlan_pool_descr.current.0.fvnsVlanInstP.attributes.dn == 'uni/infra/vlanns-[anstest]-static'
- nm_add_static_vlan_pool_descr.current.0.fvnsVlanInstP.attributes.name == 'anstest'
- name: Change description of static vlan pool again (check_mode)
aci_vlan_pool:
<<: *static_vlan_pool_present
description: Ansible test static vlan pool
check_mode: yes
register: cm_add_static_vlan_pool_descr_again
- name: Change description of static vlan pool again (normal mode)
aci_vlan_pool:
<<: *static_vlan_pool_present
description: Ansible test static vlan pool
register: nm_add_static_vlan_pool_descr_again
- name: Verify add_static_vlan_pool_descr_again
assert:
that:
- cm_add_static_vlan_pool_descr_again.changed == nm_add_static_vlan_pool_descr_again.changed == false
- cm_add_static_vlan_pool_descr_again.current == nm_add_static_vlan_pool_descr_again.current == nm_add_static_vlan_pool_descr.current
# ADD VLAN POOL AGAIN
- name: Add static vlan pool again with no description (check_mode)
aci_vlan_pool: *static_vlan_pool_present
check_mode: yes
register: cm_add_static_vlan_pool_again_no_descr
- name: Add static vlan pool again with no description (normal mode)
aci_vlan_pool: *static_vlan_pool_present
register: nm_add_static_vlan_pool_again_no_descr
- name: Verify add_static_vlan_pool_again_no_descr
assert:
that:
- cm_add_static_vlan_pool_again_no_descr.changed == nm_add_static_vlan_pool_again_no_descr.changed == false
- cm_add_static_vlan_pool_again_no_descr.current == nm_add_static_vlan_pool_again_no_descr.current == nm_add_static_vlan_pool_descr.current
# QUERY ALL VLAN POOLS
- name: Query all static vlan pools (check_mode)
aci_vlan_pool: &static_vlan_pool_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_static_vlan_pools
- name: Query all static vlan pools (normal mode)
aci_vlan_pool: *static_vlan_pool_query
register: nm_query_all_static_vlan_pools
- name: Verify query_all_static_vlan_pools
assert:
that:
- cm_query_all_static_vlan_pools.changed == nm_query_all_static_vlan_pools.changed == false
- cm_query_all_static_vlan_pools == nm_query_all_static_vlan_pools
- cm_query_all_static_vlan_pools.current|length >= 1
# QUERY A VLAN POOL
- name: Query our static vlan pool
aci_vlan_pool:
<<: *static_vlan_pool_query
pool: anstest
pool_allocation_mode: static
check_mode: yes
register: cm_query_static_vlan_pool
- name: Query our static vlan pool
aci_vlan_pool:
<<: *static_vlan_pool_query
pool: anstest
pool_allocation_mode: static
register: nm_query_static_vlan_pool
- name: Verify query_static_vlan_pool
assert:
that:
- cm_query_static_vlan_pool.changed == nm_query_static_vlan_pool.changed == false
- cm_query_static_vlan_pool == nm_query_static_vlan_pool
- nm_query_static_vlan_pool.current.0.fvnsVlanInstP.attributes.allocMode == 'static'
- nm_query_static_vlan_pool.current.0.fvnsVlanInstP.attributes.descr == 'Ansible test static vlan pool'
- nm_query_static_vlan_pool.current.0.fvnsVlanInstP.attributes.dn == 'uni/infra/vlanns-[anstest]-static'
- nm_query_static_vlan_pool.current.0.fvnsVlanInstP.attributes.name == 'anstest'
# REMOVE VLAN POOL
- name: Remove static vlan pool (check_mode)
aci_vlan_pool: *static_vlan_pool_absent
check_mode: yes
register: cm_remove_static_vlan_pool
- name: Remove static vlan pool (normal mode)
aci_vlan_pool: *static_vlan_pool_absent
register: nm_remove_static_vlan_pool
- name: Verify remove_static_vlan_pool
assert:
that:
- cm_remove_static_vlan_pool.changed == nm_remove_static_vlan_pool.changed == true
- 'cm_remove_static_vlan_pool.current == cm_remove_static_vlan_pool.previous == nm_remove_static_vlan_pool.previous == [{"fvnsVlanInstP": {"attributes": {"allocMode": "static", "descr": "Ansible test static vlan pool", "dn": "uni/infra/vlanns-[anstest]-static", "name": "anstest", "nameAlias": "", "ownerKey": "", "ownerTag": ""}}}]'
- nm_remove_static_vlan_pool.current == []
- name: Remove static vlan pool again (check_mode)
aci_vlan_pool: *static_vlan_pool_absent
check_mode: yes
register: cm_remove_static_vlan_pool_again
- name: Remove static vlan pool again (normal mode)
aci_vlan_pool: *static_vlan_pool_absent
register: nm_remove_static_vlan_pool_again
- name: Verify remove_static_vlan_pool_again
assert:
that:
- cm_remove_static_vlan_pool_again.changed == nm_remove_static_vlan_pool_again.changed == false
- cm_remove_static_vlan_pool_again.proposed == nm_remove_static_vlan_pool_again.proposed == {}
- cm_remove_static_vlan_pool_again.sent == nm_remove_static_vlan_pool_again.sent == {}
- cm_remove_static_vlan_pool_again.previous == nm_remove_static_vlan_pool_again.previous == []
- cm_remove_static_vlan_pool_again.current == nm_remove_static_vlan_pool_again.current == []
# QUERY NON-EXISTING VLAN POOL
- name: Query non-existing static vlan pool (check_mode)
aci_vlan_pool:
<<: *static_vlan_pool_query
pool: anstest
pool_allocation_mode: static
check_mode: yes
register: cm_query_non_static_vlan_pool
- name: Query non-existing static vlan pool (normal mode)
aci_vlan_pool:
<<: *static_vlan_pool_query
pool: anstest
pool_allocation_mode: static
register: nm_query_non_static_vlan_pool
# TODO: Implement more tests
- name: Verify query_non_static_vlan_pool
assert:
that:
- cm_query_non_static_vlan_pool.changed == nm_query_non_static_vlan_pool.changed == false
- cm_remove_static_vlan_pool_again.previous == nm_remove_static_vlan_pool_again.previous == []
- cm_remove_static_vlan_pool_again.current == nm_remove_static_vlan_pool_again.current == []
# PROVOKE ERRORS
- name: Error when required parameter is missing
aci_vlan_pool:
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: Verify error_on_missing_required_param
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: pool"'
- name: Error when together parameter is missing
aci_vlan_pool:
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
pool: anstest
state: present
ignore_errors: yes
register: error_on_missing_together_param
- name: Verify error_on_missing_together_param
assert:
that:
- error_on_missing_together_param.failed == true
- error_on_missing_together_param.msg == "ACI requires the 'pool_allocation_mode' when 'pool' is provided"