diff options
author | Kevin Breit <kevin.breit@kevinbreit.net> | 2018-05-15 22:42:09 +0200 |
---|---|---|
committer | Dag Wieers <dag@wieers.com> | 2018-05-15 22:42:09 +0200 |
commit | cd89bc59418d717d59f1fb069af92b75f58a1be8 (patch) | |
tree | eb7dc527ba426dc6ddcef119bc7e51ccadcd5856 /test/integration/targets/meraki_network | |
parent | Meraki: Improved integration testing and results (#39761) (diff) | |
download | ansible-cd89bc59418d717d59f1fb069af92b75f58a1be8.tar.xz ansible-cd89bc59418d717d59f1fb069af92b75f58a1be8.zip |
New module - meraki_network (#39782)
* New module for CRUD functionality of networks in a Meraki environment
- Relatively full integration test suite
- More functions to come
* Fix indent for PEP8.
- Look into why this didn't show on a local PEP8 test
* Dag requested changes.
- Removed a section in get_net as its backend isn't implemented
- Documentation modifications
Diffstat (limited to 'test/integration/targets/meraki_network')
-rw-r--r-- | test/integration/targets/meraki_network/aliases | 1 | ||||
-rw-r--r-- | test/integration/targets/meraki_network/tasks/main.yml | 235 |
2 files changed, 236 insertions, 0 deletions
diff --git a/test/integration/targets/meraki_network/aliases b/test/integration/targets/meraki_network/aliases new file mode 100644 index 0000000000..ad7ccf7ada --- /dev/null +++ b/test/integration/targets/meraki_network/aliases @@ -0,0 +1 @@ +unsupported diff --git a/test/integration/targets/meraki_network/tasks/main.yml b/test/integration/targets/meraki_network/tasks/main.yml new file mode 100644 index 0000000000..c02ad1ee8d --- /dev/null +++ b/test/integration/targets/meraki_network/tasks/main.yml @@ -0,0 +1,235 @@ +# Test code for the Meraki modules +# Copyright: (c) 2018, Kevin Breit (@kbreit) + +# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) +--- +- name: Create network without type + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetwork + timezone: America/Chicago + delegate_to: localhost + register: create_net_no_type + ignore_errors: yes + +- name: Create network without organization + meraki_network: + auth_key: '{{ auth_key }}' + state: present + net_name: IntTestNetwork + timezone: America/Chicago + delegate_to: localhost + register: create_net_no_org + ignore_errors: yes + +- name: Create network with type switch + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkSwitch + type: switch + timezone: America/Chicago + delegate_to: localhost + register: create_net_switch + +- name: Create network with type switch by org ID + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_id: '{{test_org_id}}' + net_name: IntTestNetworkSwitchOrgID + type: switch + timezone: America/Chicago + delegate_to: localhost + register: create_net_switch_org_id + +- name: Create network with type appliance and no timezone + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkAppliance + type: appliance + delegate_to: localhost + register: create_net_appliance_no_tz + +- name: Create network with type wireless + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkWireless + type: wireless + timezone: America/Chicago + delegate_to: localhost + register: create_net_wireless + +- name: Create network with type combined + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkCombined + type: combined + timezone: America/Chicago + delegate_to: localhost + register: create_net_combined + +- name: Create network with one tag + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkTag + type: switch + timezone: America/Chicago + tags: first_tag + delegate_to: localhost + register: create_net_tag + +- debug: + msg: '{{create_net_tag}}' + +- name: Create network with two tags + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkTags + type: switch + timezone: America/Chicago + tags: first_tag, second_tag + delegate_to: localhost + register: create_net_tags + +- debug: + msg: '{{create_net_tags}}' + +- name: Modify network + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkTags + type: switch + timezone: America/Chicago + tags: first_tag, second_tag, third_tag + delegate_to: localhost + register: create_net_modified + +- name: Modify network with idempotency + meraki_network: + auth_key: '{{ auth_key }}' + state: present + org_name: '{{test_org_name}}' + net_name: IntTestNetworkTags + type: switch + timezone: America/Chicago + tags: first_tag, second_tag, third_tag + delegate_to: localhost + register: create_net_modified_idempotent + +- name: Present assertions + assert: + that: + - create_net_no_type.status == 500 + - '"org_name or org_id parameters are required" in create_net_no_org.msg' + - '"IntTestNetworkAppliance" in create_net_appliance_no_tz.data.name' + - create_net_appliance_no_tz.changed == True + - '"IntTestNetworkSwitch" in create_net_switch.data.name' + - '"IntTestNetworkSwitchOrgID" in create_net_switch_org_id.data.name' + - '"IntTestNetworkWireless" in create_net_wireless.data.name' + - '"first_tag" in create_net_tag.data.tags' + - '"second_tag" in create_net_tags.data.tags' + - '"third_tag" in create_net_modified.data.tags' + - create_net_modified.changed == True + - create_net_modified_idempotent.changed == False + +- name: Query all networks + meraki_network: + auth_key: '{{ auth_key }}' + state: query + org_name: '{{test_org_name}}' + delegate_to: localhost + register: net_query_all + +- name: Query one network + meraki_network: + auth_key: '{{ auth_key }}' + state: query + org_name: '{{test_org_name}}' + net_name: IntTestNetworkSwitch + delegate_to: localhost + register: net_query_one + +- name: Query assertions + assert: + that: + - net_query_all.data | length == 7 + - 'net_query_one.data.name == "IntTestNetworkSwitch"' + +- name: Delete network without org + meraki_network: + auth_key: '{{ auth_key }}' + state: absent + net_name: IntTestNetworkSwitch + delegate_to: localhost + register: delete_all_no_org + ignore_errors: yes + +- debug: + msg: '{{delete_all_no_org}}' + +- name: Delete network by org ID + meraki_network: + auth_key: '{{ auth_key }}' + state: absent + org_id: '{{test_org_id}}' + net_name: IntTestNetworkSwitchOrgID + delegate_to: localhost + register: delete_net_org_id + +- debug: + msg: '{{delete_net_org_id}}' + +- name: Query after delete with org ID + meraki_network: + auth_key: '{{ auth_key }}' + state: query + org_name: '{{test_org_name}}' + delegate_to: localhost + register: query_deleted_org_id + +- name: Delete all networks + meraki_network: + auth_key: '{{ auth_key }}' + state: absent + org_name: '{{test_org_name}}' + net_name: '{{ item }}' + delegate_to: localhost + register: delete_all + loop: + - IntTestNetworkSwitch + - IntTestNetworkWireless + - IntTestNetworkAppliance + - IntTestNetworkCombined + - IntTestNetworkTag + - IntTestNetworkTags + +- name: Query after delete all + meraki_network: + auth_key: '{{ auth_key }}' + state: query + org_name: '{{test_org_name}}' + delegate_to: localhost + register: query_deleted + +- name: Delete assertions + assert: + that: + - '"org_name or org_id parameters are required" in delete_all_no_org.msg' + - query_deleted_org_id.data | length == 6 + - query_deleted.data | length == 0
\ No newline at end of file |