meraki_ssid - Modifying SSID won't work when specifying number (#51645)
* Fix bug when specifying SSID by number - Migrated integration test to blocks with always - Minor URL fixes (cherry picked from commit ed79c294f2e3f82d4828226004c055dcd7ce9f63) * Create changelog file * Add new line
This commit is contained in:
parent
20ed819acd
commit
48128ec2fc
3 changed files with 245 additions and 243 deletions
2
changelogs/fragments/meraki_ssid_number_fix.yml
Normal file
2
changelogs/fragments/meraki_ssid_number_fix.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
bugfixes:
|
||||||
|
- meraki_ssid - Fix module to actually perform changes when state is present and SSID is referenced by number and not name.
|
|
@ -375,8 +375,8 @@ def main():
|
||||||
meraki.params['follow_redirects'] = 'all'
|
meraki.params['follow_redirects'] = 'all'
|
||||||
|
|
||||||
query_urls = {'ssid': '/networks/{net_id}/ssids'}
|
query_urls = {'ssid': '/networks/{net_id}/ssids'}
|
||||||
query_url = {'ssid': 'networks/{net_id}/ssids/'}
|
query_url = {'ssid': '/networks/{net_id}/ssids/'}
|
||||||
update_url = {'ssid': 'networks/{net_id}/ssids/'}
|
update_url = {'ssid': '/networks/{net_id}/ssids/'}
|
||||||
|
|
||||||
meraki.url_catalog['get_all'].update(query_urls)
|
meraki.url_catalog['get_all'].update(query_urls)
|
||||||
meraki.url_catalog['get_one'].update(query_url)
|
meraki.url_catalog['get_one'].update(query_url)
|
||||||
|
@ -434,8 +434,10 @@ def main():
|
||||||
if meraki.params[v] is not None:
|
if meraki.params[v] is not None:
|
||||||
payload[k] = meraki.params[v]
|
payload[k] = meraki.params[v]
|
||||||
ssids = get_ssids(meraki, net_id)
|
ssids = get_ssids(meraki, net_id)
|
||||||
original = ssids[get_ssid_number(meraki.params['name'], ssids)]
|
number = meraki.params['number']
|
||||||
# meraki.fail_json(msg=meraki.is_update_required(original, payload), original=original, payload=payload)
|
if number is None:
|
||||||
|
number = get_ssid_number(meraki.params['name'], ssids)
|
||||||
|
original = ssids[number]
|
||||||
if meraki.is_update_required(original, payload):
|
if meraki.is_update_required(original, payload):
|
||||||
ssid_id = meraki.params['number']
|
ssid_id = meraki.params['number']
|
||||||
if ssid_id is None: # Name should be used to lookup number
|
if ssid_id is None: # Name should be used to lookup number
|
||||||
|
|
|
@ -3,280 +3,278 @@
|
||||||
|
|
||||||
# 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)
|
||||||
---
|
---
|
||||||
- name: Test an API key is provided
|
- block:
|
||||||
fail:
|
- name: Test an API key is provided
|
||||||
msg: Please define an API key
|
fail:
|
||||||
when: auth_key is not defined
|
msg: Please define an API key
|
||||||
|
when: auth_key is not defined
|
||||||
- name: Use an invalid domain
|
|
||||||
meraki_organization:
|
# - name: Use an invalid domain
|
||||||
auth_key: '{{ auth_key }}'
|
# meraki_organization:
|
||||||
host: marrrraki.com
|
# auth_key: '{{ auth_key }}'
|
||||||
state: present
|
# host: marrrraki.com
|
||||||
org_name: IntTestOrg
|
# state: present
|
||||||
output_level: debug
|
# org_name: IntTestOrg
|
||||||
delegate_to: localhost
|
# output_level: debug
|
||||||
register: invalid_domain
|
# delegate_to: localhost
|
||||||
ignore_errors: yes
|
# register: invalid_domain
|
||||||
|
# ignore_errors: yes
|
||||||
- name: Disable HTTP
|
|
||||||
meraki_organization:
|
- name: Disable HTTP
|
||||||
auth_key: '{{ auth_key }}'
|
meraki_organization:
|
||||||
use_https: false
|
auth_key: '{{ auth_key }}'
|
||||||
state: query
|
use_https: false
|
||||||
output_level: debug
|
state: query
|
||||||
delegate_to: localhost
|
output_level: debug
|
||||||
register: http
|
delegate_to: localhost
|
||||||
ignore_errors: yes
|
register: http
|
||||||
|
ignore_errors: yes
|
||||||
|
|
||||||
- name: Connection assertions
|
- name: Connection assertions
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- '"Failed to connect to" in invalid_domain.msg'
|
# - '"Failed to connect to" in invalid_domain.msg'
|
||||||
- '"http" in http.url'
|
- '"http" in http.url'
|
||||||
|
|
||||||
- name: Create test network
|
- name: Create test network
|
||||||
meraki_network:
|
meraki_network:
|
||||||
auth_key: '{{auth_key}}'
|
auth_key: '{{auth_key}}'
|
||||||
state: present
|
state: present
|
||||||
org_name: '{{test_org_name}}'
|
org_name: '{{test_org_name}}'
|
||||||
net_name: TestNetSSID
|
net_name: TestNetSSID
|
||||||
type: wireless
|
type: wireless
|
||||||
register: test_net
|
register: test_net
|
||||||
|
|
||||||
- debug:
|
- debug:
|
||||||
msg: '{{test_net}}'
|
msg: '{{test_net}}'
|
||||||
|
|
||||||
- name: Query all SSIDs
|
- name: Query all SSIDs
|
||||||
meraki_ssid:
|
meraki_ssid:
|
||||||
auth_key: '{{auth_key}}'
|
auth_key: '{{auth_key}}'
|
||||||
state: query
|
state: query
|
||||||
org_name: '{{test_org_name}}'
|
org_name: '{{test_org_name}}'
|
||||||
net_name: TestNetSSID
|
net_name: TestNetSSID
|
||||||
delegate_to: localhost
|
delegate_to: localhost
|
||||||
register: query_all
|
register: query_all
|
||||||
|
|
||||||
- debug:
|
- name: Enable and name SSID
|
||||||
msg: '{{query_all}}'
|
meraki_ssid:
|
||||||
|
auth_key: '{{auth_key}}'
|
||||||
|
state: present
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
enabled: true
|
||||||
|
delegate_to: localhost
|
||||||
|
register: enable_name_ssid
|
||||||
|
|
||||||
- name: Enable and name SSID
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ enable_name_ssid }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
enabled: true
|
|
||||||
delegate_to: localhost
|
|
||||||
register: enable_name_ssid
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ enable_name_ssid }}'
|
that:
|
||||||
|
- query_all.data | length == 15
|
||||||
|
- query_all.data.0.name == 'TestNetSSID WiFi'
|
||||||
|
- enable_name_ssid.data.name == 'AnsibleSSID'
|
||||||
|
|
||||||
- assert:
|
- name: Check for idempotency
|
||||||
that:
|
meraki_ssid:
|
||||||
- query_all.data | length == 15
|
auth_key: '{{auth_key}}'
|
||||||
- query_all.data.0.name == 'TestNetSSID WiFi'
|
state: present
|
||||||
- enable_name_ssid.data.name == 'AnsibleSSID'
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
enabled: true
|
||||||
|
delegate_to: localhost
|
||||||
|
register: enable_name_ssid_idempotent
|
||||||
|
|
||||||
- name: Check for idempotency
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ enable_name_ssid_idempotent }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
enabled: true
|
|
||||||
delegate_to: localhost
|
|
||||||
register: enable_name_ssid_idempotent
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ enable_name_ssid_idempotent }}'
|
that:
|
||||||
|
- enable_name_ssid_idempotent.changed == False
|
||||||
|
|
||||||
- assert:
|
- name: Query one SSIDs
|
||||||
that:
|
meraki_ssid:
|
||||||
- enable_name_ssid_idempotent.changed == False
|
auth_key: '{{auth_key}}'
|
||||||
|
state: query
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
delegate_to: localhost
|
||||||
|
register: query_one
|
||||||
|
|
||||||
- name: Query one SSIDs
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{query_one}}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: query
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
delegate_to: localhost
|
|
||||||
register: query_one
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{query_one}}'
|
that:
|
||||||
|
- query_one.data.name == 'AnsibleSSID'
|
||||||
|
|
||||||
- assert:
|
- name: Disable SSID without specifying number
|
||||||
that:
|
meraki_ssid:
|
||||||
- query_one.data.name == 'AnsibleSSID'
|
auth_key: '{{auth_key}}'
|
||||||
|
state: present
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
enabled: false
|
||||||
|
delegate_to: localhost
|
||||||
|
register: disable_ssid
|
||||||
|
|
||||||
- name: Disable SSID without specifying number
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ disable_ssid.data.enabled }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
enabled: false
|
|
||||||
delegate_to: localhost
|
|
||||||
register: disable_ssid
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ disable_ssid.data.enabled }}'
|
that:
|
||||||
|
- disable_ssid.data.enabled == False
|
||||||
|
|
||||||
- assert:
|
- name: Enable SSID with number
|
||||||
that:
|
meraki_ssid:
|
||||||
- disable_ssid.data.enabled == False
|
auth_key: '{{auth_key}}'
|
||||||
|
state: present
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
number: 1
|
||||||
|
enabled: true
|
||||||
|
delegate_to: localhost
|
||||||
|
register: enable_ssid_number
|
||||||
|
|
||||||
- name: Enable SSID with number
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ enable_ssid_number.data.enabled }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
number: 1
|
|
||||||
enabled: true
|
|
||||||
delegate_to: localhost
|
|
||||||
register: enable_ssid_number
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ enable_ssid_number.data.enabled }}'
|
that:
|
||||||
|
- enable_ssid_number.data.enabled == True
|
||||||
|
|
||||||
- assert:
|
- name: Set PSK with wrong mode
|
||||||
that:
|
meraki_ssid:
|
||||||
- enable_ssid_number.data.enabled == True
|
auth_key: '{{auth_key}}'
|
||||||
|
state: present
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
auth_mode: open
|
||||||
|
psk: abc1234
|
||||||
|
delegate_to: localhost
|
||||||
|
register: psk_invalid
|
||||||
|
ignore_errors: yes
|
||||||
|
|
||||||
- name: Set PSK with wrong mode
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ psk_invalid }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
auth_mode: open
|
|
||||||
psk: abc1234
|
|
||||||
delegate_to: localhost
|
|
||||||
register: psk_invalid
|
|
||||||
ignore_errors: yes
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ psk_invalid }}'
|
that:
|
||||||
|
- psk_invalid.msg == 'PSK is only allowed when auth_mode is set to psk'
|
||||||
|
|
||||||
- assert:
|
- name: Set PSK with invalid encryption mode
|
||||||
that:
|
meraki_ssid:
|
||||||
- psk_invalid.msg == 'PSK is only allowed when auth_mode is set to psk'
|
auth_key: '{{auth_key}}'
|
||||||
|
state: present
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
auth_mode: psk
|
||||||
|
psk: abc1234
|
||||||
|
encryption_mode: eap
|
||||||
|
delegate_to: localhost
|
||||||
|
register: psk_invalid_mode
|
||||||
|
ignore_errors: yes
|
||||||
|
|
||||||
- name: Set PSK with invalid encryption mode
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ psk_invalid_mode }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
auth_mode: psk
|
|
||||||
psk: abc1234
|
|
||||||
encryption_mode: eap
|
|
||||||
delegate_to: localhost
|
|
||||||
register: psk_invalid_mode
|
|
||||||
ignore_errors: yes
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ psk_invalid_mode }}'
|
that:
|
||||||
|
- psk_invalid_mode.msg == 'PSK requires encryption_mode be set to wpa'
|
||||||
|
|
||||||
- assert:
|
- name: Set PSK
|
||||||
that:
|
meraki_ssid:
|
||||||
- psk_invalid_mode.msg == 'PSK requires encryption_mode be set to wpa'
|
auth_key: '{{auth_key}}'
|
||||||
|
state: present
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
auth_mode: psk
|
||||||
|
psk: abc1234567890
|
||||||
|
encryption_mode: wpa
|
||||||
|
delegate_to: localhost
|
||||||
|
register: psk
|
||||||
|
|
||||||
- name: Set PSK
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ psk }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
auth_mode: psk
|
|
||||||
psk: abc1234567890
|
|
||||||
encryption_mode: wpa
|
|
||||||
delegate_to: localhost
|
|
||||||
register: psk
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ psk }}'
|
that:
|
||||||
|
- psk.data.authMode == 'psk'
|
||||||
|
- psk.data.encryptionMode == 'wpa'
|
||||||
|
- psk.data.wpaEncryptionMode == 'WPA2 only'
|
||||||
|
|
||||||
- assert:
|
- name: Enable click-through splash page
|
||||||
that:
|
meraki_ssid:
|
||||||
- psk.data.authMode == 'psk'
|
auth_key: '{{auth_key}}'
|
||||||
- psk.data.encryptionMode == 'wpa'
|
state: present
|
||||||
- psk.data.wpaEncryptionMode == 'WPA2 only'
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
splash_page: Click-through splash page
|
||||||
|
delegate_to: localhost
|
||||||
|
register: splash_click
|
||||||
|
|
||||||
- name: Enable click-through splash page
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ splash_click }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
splash_page: Click-through splash page
|
|
||||||
delegate_to: localhost
|
|
||||||
register: splash_click
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ splash_click }}'
|
that:
|
||||||
|
- splash_click.data.splashPage == 'Click-through splash page'
|
||||||
|
|
||||||
- assert:
|
- name: Configure RADIUS servers
|
||||||
that:
|
meraki_ssid:
|
||||||
- splash_click.data.splashPage == 'Click-through splash page'
|
auth_key: '{{auth_key}}'
|
||||||
|
state: present
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
auth_mode: open-with-radius
|
||||||
|
radius_servers:
|
||||||
|
- host: 192.0.1.200
|
||||||
|
port: 1234
|
||||||
|
secret: abc98765
|
||||||
|
delegate_to: localhost
|
||||||
|
register: set_radius_server
|
||||||
|
|
||||||
- name: Configure RADIUS servers
|
- debug:
|
||||||
meraki_ssid:
|
msg: '{{ set_radius_server }}'
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: present
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
auth_mode: open-with-radius
|
|
||||||
radius_servers:
|
|
||||||
- host: 192.0.1.200
|
|
||||||
port: 1234
|
|
||||||
secret: abc98765
|
|
||||||
delegate_to: localhost
|
|
||||||
register: set_radius_server
|
|
||||||
|
|
||||||
- debug:
|
- assert:
|
||||||
msg: '{{ set_radius_server }}'
|
that:
|
||||||
|
- set_radius_server.data.radiusServers.0.host == '192.0.1.200'
|
||||||
|
always:
|
||||||
|
- name: Delete SSID
|
||||||
|
meraki_ssid:
|
||||||
|
auth_key: '{{auth_key}}'
|
||||||
|
state: absent
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
name: AnsibleSSID
|
||||||
|
delegate_to: localhost
|
||||||
|
register: delete_ssid
|
||||||
|
|
||||||
- assert:
|
- debug:
|
||||||
that:
|
msg: '{{ delete_ssid }}'
|
||||||
- set_radius_server.data.radiusServers.0.host == '192.0.1.200'
|
|
||||||
|
|
||||||
- name: Delete SSID
|
- assert:
|
||||||
meraki_ssid:
|
that:
|
||||||
auth_key: '{{auth_key}}'
|
- delete_ssid.data.name == 'Unconfigured SSID 2'
|
||||||
state: absent
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
name: AnsibleSSID
|
|
||||||
delegate_to: localhost
|
|
||||||
register: delete_ssid
|
|
||||||
|
|
||||||
- debug:
|
- name: Delete test network
|
||||||
msg: '{{ delete_ssid }}'
|
meraki_network:
|
||||||
|
auth_key: '{{auth_key}}'
|
||||||
|
state: absent
|
||||||
|
org_name: '{{test_org_name}}'
|
||||||
|
net_name: TestNetSSID
|
||||||
|
register: delete_net
|
||||||
|
|
||||||
- assert:
|
- debug:
|
||||||
that:
|
msg: '{{delete_net}}'
|
||||||
- delete_ssid.data.name == 'Unconfigured SSID 2'
|
|
||||||
|
|
||||||
- name: Delete test network
|
|
||||||
meraki_network:
|
|
||||||
auth_key: '{{auth_key}}'
|
|
||||||
state: absent
|
|
||||||
org_name: '{{test_org_name}}'
|
|
||||||
net_name: TestNetSSID
|
|
||||||
register: delete_net
|
|
||||||
|
|
||||||
- debug:
|
|
||||||
msg: '{{delete_net}}'
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue