--- - debug: msg="START connection={{ ansible_connection }} nxos_vrrp sanity test" - debug: msg="Using provider={{ connection.transport }}" when: ansible_connection == "local" - block: - name: "Enable interface-vlan" nxos_feature: feature: interface-vlan provider: "{{ connection }}" state: enabled - name: "Enable vrrp" nxos_feature: feature: vrrp provider: "{{ connection }}" state: enabled - name: "create int vlan 10" nxos_config: commands: "int vlan 10" provider: "{{ connection }}" - name: Ensure vrrp group 100 and vip 10.1.100.1 is on vlan10 nxos_vrrp: &configure interface: vlan10 group: 100 vip: 10.1.100.1 admin_state: 'no shutdown' provider: "{{ connection }}" register: result - assert: &true that: - "result.changed == true" - name: "Conf Idempotence" nxos_vrrp: *configure register: result - assert: &false that: - "result.changed == false" - name: Ensure vrrp group 100 is default nxos_vrrp: &configure_def interface: vlan10 group: 100 vip: default admin_state: default provider: "{{ connection }}" register: result - assert: *true - name: "Conf Idempotence" nxos_vrrp: *configure_def register: result - assert: *false - name: Ensure removal of the vrrp group config nxos_vrrp: &remove interface: vlan10 group: 100 provider: "{{ connection }}" state: absent register: result - assert: *true - pause: seconds: 30 - name: "Remove Idempotence" nxos_vrrp: *remove register: result - assert: *false - pause: seconds: 30 - name: Re-config with more params nxos_vrrp: &reconfig interface: vlan10 group: 100 vip: 10.1.100.1 preempt: False interval: 10 priority: 130 authentication: AUTHKEY provider: "{{ connection }}" register: result - assert: *true - name: "Reconfig Idempotence" nxos_vrrp: *reconfig register: result - assert: *false - name: Re-config with defaults nxos_vrrp: &reconfig_def interface: vlan10 group: 100 vip: default preempt: True interval: default priority: default authentication: default provider: "{{ connection }}" register: result - assert: *true - name: "Reconfig Idempotence" nxos_vrrp: *reconfig_def register: result - assert: *false always: - name: remove vrrp nxos_vrrp: *remove ignore_errors: yes - name: "Disable interface-vlan" nxos_config: commands: - no feature interface-vlan match: none provider: "{{ connection }}" ignore_errors: yes - name: "Disable vrrp" nxos_feature: feature: vrrp provider: "{{ connection }}" state: disabled ignore_errors: yes - debug: msg="END connection={{ ansible_connection }} nxos_vrrp sanity test"