ansible/test/integration/targets/ios_interface/tests/cli/basic.yaml

266 lines
6.7 KiB
YAML
Raw Normal View History

---
- debug: msg="START ios_interface cli/basic.yaml"
- name: Run show version
ios_command:
commands: show version
authorize: yes
register: show_version_result
- name: Set test interface to GigabitEthernet0/1 if we are on Cisco IOS
set_fact: test_interface=GigabitEthernet0/1
when: "'Cisco IOS' in show_version_result.stdout[0]"
- name: Set test interface 2 to GigabitEthernet0/2 if we are on Cisco IOS
set_fact: test_interface2=GigabitEthernet0/2
when: "'Cisco IOS' in show_version_result.stdout[0]"
- name: Set test interface to GigabitEthernet2 if we are on Cisco IOS-XE
set_fact: test_interface=GigabitEthernet2
when: "'Cisco IOS-XE' in show_version_result.stdout[0]"
- name: Set test interface 2 to GigabitEthernet3 if we are on Cisco IOS-XE
set_fact: test_interface2=GigabitEthernet3
when: "'Cisco IOS-XE' in show_version_result.stdout[0]"
- name: Configure interface (setup)
ios_interface:
name: "{{ test_interface }}"
description: test-interface-1
speed: 10
duplex: full
mtu: 256
state: present
authorize: yes
register: result
- name: Confgure interface
ios_interface:
name: "{{ test_interface }}"
description: test-interface-initial
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface GigabitEthernet0/2" in result.commands'
- '"description test-interface-initial" in result.commands'
- name: Confgure interface (idempotent)
ios_interface:
name: "{{ test_interface }}"
description: test-interface-initial
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == false'
- name: Confgure interface parameters
ios_interface:
name: "{{ test_interface }}"
description: test-interface
speed: 100
mtu: 512
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface {{ test_interface }}" in result.commands'
- '"description test-interface" in result.commands'
- '"speed 100" in result.commands'
- '"mtu 512" in result.commands'
- name: Change interface parameters
ios_interface:
name: "{{ test_interface }}"
description: test-interface-1
speed: 10
duplex: half
mtu: 256
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface {{ test_interface }}" in result.commands'
- '"description test-interface-1" in result.commands'
- '"speed 10" in result.commands'
- '"duplex half" in result.commands'
- '"mtu 256" in result.commands'
- name: Disable interface
ios_interface:
name: "{{ test_interface }}"
enabled: False
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface {{ test_interface }}" in result.commands'
- '"shutdown" in result.commands'
- name: Enable interface
ios_interface:
name: "{{ test_interface }}"
enabled: True
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface {{ test_interface }}" in result.commands'
- '"no shutdown" in result.commands'
- name: Confgure second interface (setup)
ios_interface:
name: "{{ test_interface2 }}"
description: test-interface-initial
speed: 100
duplex: half
mtu: 516
state: present
authorize: yes
register: result
- name: Add interface aggregate
ios_interface:
aggregate:
- "{ name: {{ test_interface }}, mtu: 256, description: test-interface-1 }"
- "{ name: {{ test_interface2 }}, mtu: 516, description: test-interface-2 }"
duplex: full
speed: 100
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface {{ test_interface }}" in result.commands'
- '"speed 100" in result.commands'
- '"description test-interface-1" in result.commands'
- '"duplex full" in result.commands'
- '"mtu 256" in result.commands'
- '"interface {{ test_interface2 }}" in result.commands'
- '"speed 100" in result.commands'
- '"description test-interface-2" in result.commands'
- '"duplex full" in result.commands'
- '"mtu 516" in result.commands'
- name: Add interface aggregate (idempotent)
ios_interface:
aggregate:
- "{ name: {{ test_interface }}, mtu: 256, description: test-interface-1 }"
- "{ name: {{ test_interface2 }}, mtu: 516, description: test-interface-2 }"
duplex: full
speed: 100
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == false'
- name: Disable interface aggregate
ios_interface:
aggregate:
- "name: {{ test_interface }}"
- "name: {{ test_interface2 }}"
enabled: False
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface {{ test_interface }}" in result.commands'
- '"shutdown" in result.commands'
- '"interface {{ test_interface2 }}" in result.commands'
- '"shutdown" in result.commands'
- name: Enable interface aggregate
ios_interface:
aggregate:
- "name: {{ test_interface }}"
- "name: {{ test_interface2 }}"
enabled: True
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface {{ test_interface }}" in result.commands'
- '"no shutdown" in result.commands'
- '"interface {{ test_interface2 }}" in result.commands'
- '"no shutdown" in result.commands'
- name: loopback interface setup
ios_interface:
aggregate:
- name: Loopback9
- name: Loopback10
state: absent
authorize: yes
- name: Create loopback interface aggregate
ios_interface:
aggregate:
- name: Loopback9
- name: Loopback10
state: present
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"interface Loopback9" in result.commands'
- '"interface Loopback10" in result.commands'
- name: Delete loopback interface aggregate
ios_interface:
aggregate:
- name: Loopback9
- name: Loopback10
state: absent
authorize: yes
register: result
- assert:
that:
- 'result.changed == true'
- '"no interface Loopback9" in result.commands'
- '"no interface Loopback10" in result.commands'
- name: Delete loopback interface aggregate (idempotent)
ios_interface:
aggregate:
- name: Loopback9
- name: Loopback10
state: absent
authorize: yes
register: result
- assert:
that:
- 'result.changed == false'
- debug: msg="END ios_interface cli/basic.yaml"