Fix platform agnostic network integration test cases (#32378)
* Fix platform agnostic network test cases * Fix vyos_interface CI failure
This commit is contained in:
parent
53fead7c96
commit
5d1ed1fc25
26 changed files with 659 additions and 255 deletions
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
|
||||
- name: setup - remove login
|
||||
eos_banner:
|
||||
net_banner:
|
||||
banner: login
|
||||
state: absent
|
||||
authorize: yes
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
|
||||
- name: setup - remove motd
|
||||
eos_banner:
|
||||
net_banner:
|
||||
banner: motd
|
||||
state: absent
|
||||
authorize: yes
|
||||
|
@ -49,6 +49,43 @@
|
|||
# Ensure sessions contains epoc. Will fail after 18th May 2033
|
||||
- "result.session_name is not defined"
|
||||
|
||||
- name: Remove motd
|
||||
net_banner:
|
||||
banner: motd
|
||||
text: |
|
||||
this is my motd banner
|
||||
that has a multiline
|
||||
string
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'no banner motd' in result.commands"
|
||||
# Ensure sessions contains epoc. Will fail after 18th May 2033
|
||||
- "'ansible_1' in result.session_name"
|
||||
|
||||
- name: Remove motd again (idempotent)
|
||||
net_banner:
|
||||
banner: motd
|
||||
text: |
|
||||
this is my motd banner
|
||||
that has a multiline
|
||||
string
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == false"
|
||||
- "result.commands | length == 0"
|
||||
# Ensure sessions contains epoc. Will fail after 18th May 2033
|
||||
- "result.session_name is not defined"
|
||||
|
||||
# FIXME add in tests for everything defined in docs
|
||||
# FIXME Test state:absent + test:
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
---
|
||||
- name: Setup
|
||||
eos_banner:
|
||||
net_banner:
|
||||
banner: login
|
||||
text: |
|
||||
Junk login banner
|
||||
|
|
|
@ -5,7 +5,6 @@
|
|||
banner: login
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
|
||||
- name: Set login
|
||||
net_banner:
|
||||
|
@ -16,7 +15,6 @@
|
|||
string
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- debug:
|
||||
|
@ -36,7 +34,6 @@
|
|||
string
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -4,7 +4,6 @@
|
|||
banner: motd
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
|
||||
- name: Set motd
|
||||
net_banner:
|
||||
|
@ -15,7 +14,6 @@
|
|||
string
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- debug:
|
||||
|
@ -35,7 +33,6 @@
|
|||
string
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -7,14 +7,12 @@
|
|||
over multiple lines
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
|
||||
- name: remove login
|
||||
net_banner:
|
||||
banner: login
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- debug:
|
||||
|
@ -30,7 +28,6 @@
|
|||
banner: login
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -94,7 +94,7 @@
|
|||
- "result.changed == false"
|
||||
|
||||
- name: delete motd banner
|
||||
junos_banner:
|
||||
net_banner:
|
||||
banner: motd
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
|
|
|
@ -1,40 +1,69 @@
|
|||
---
|
||||
- debug: msg="START net_interface cli/basic.yaml"
|
||||
|
||||
- name: Run show version
|
||||
ios_command:
|
||||
commands: show version
|
||||
authorize: yes
|
||||
register: show_version_result
|
||||
|
||||
- block:
|
||||
- name: Set test interface to GigabitEthernet0/1 as we are on Cisco IOS
|
||||
set_fact: test_interface=GigabitEthernet0/1
|
||||
- name: Set test interface 2 to GigabitEthernet0/2 as we are on Cisco IOS
|
||||
set_fact: test_interface2=GigabitEthernet0/2
|
||||
when: "'Cisco IOS' in show_version_result.stdout[0]"
|
||||
|
||||
- block:
|
||||
- name: Set test interface to GigabitEthernet2 as we are on Cisco IOS-XE
|
||||
set_fact: test_interface=GigabitEthernet2
|
||||
- name: Disable autonegotiation on GigabitEthernet2
|
||||
ios_config:
|
||||
lines:
|
||||
- no negotiation auto
|
||||
parents: int GigabitEthernet2
|
||||
authorize: yes
|
||||
|
||||
- name: Set test interface 2 to GigabitEthernet3 as we are on Cisco IOS-XE
|
||||
set_fact: test_interface2=GigabitEthernet3
|
||||
- name: Disable autonegotiation on GigabitEthernet3
|
||||
ios_config:
|
||||
lines:
|
||||
- no negotiation auto
|
||||
parents: int GigabitEthernet3
|
||||
authorize: yes
|
||||
when: "'Cisco IOS-XE' in show_version_result.stdout[0]"
|
||||
|
||||
- name: Configure interface (setup)
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
description: test-interface-1
|
||||
speed: 10
|
||||
duplex: full
|
||||
mtu: 256
|
||||
speed: 1000
|
||||
mtu: 1800
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- name: Confgure interface
|
||||
- name: Configure interface
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
description: test-interface-initial
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/2" in result.commands'
|
||||
- '"interface {{ test_interface }}" in result.commands'
|
||||
- '"description test-interface-initial" in result.commands'
|
||||
|
||||
- name: Confgure interface (idempotent)
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
description: test-interface-initial
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -43,120 +72,99 @@
|
|||
|
||||
- name: Confgure interface parameters
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
description: test-interface
|
||||
speed: 100
|
||||
mtu: 512
|
||||
mtu: 2000
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/2" in result.commands'
|
||||
- '"interface {{ test_interface }}" in result.commands'
|
||||
- '"description test-interface" in result.commands'
|
||||
- '"speed 100" in result.commands'
|
||||
- '"mtu 512" in result.commands'
|
||||
- '"mtu 2000" in result.commands'
|
||||
|
||||
- name: Change interface parameters
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
description: test-interface-1
|
||||
speed: 10
|
||||
duplex: half
|
||||
mtu: 256
|
||||
mtu: 1800
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/2" in result.commands'
|
||||
- '"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'
|
||||
- '"mtu 1800" in result.commands'
|
||||
|
||||
- name: Disable interface
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
enabled: False
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/2" in result.commands'
|
||||
- '"interface {{ test_interface }}" in result.commands'
|
||||
- '"shutdown" in result.commands'
|
||||
|
||||
- name: Enable interface
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
enabled: True
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/2" in result.commands'
|
||||
- '"interface {{ test_interface }}" in result.commands'
|
||||
- '"no shutdown" in result.commands'
|
||||
|
||||
- name: Confgure second interface (setup)
|
||||
net_interface:
|
||||
name: GigabitEthernet0/1
|
||||
name: "{{ test_interface2 }}"
|
||||
description: test-interface-initial
|
||||
speed: 100
|
||||
duplex: half
|
||||
mtu: 516
|
||||
speed: 1000
|
||||
mtu: 1800
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- name: Add interface aggregate
|
||||
net_interface:
|
||||
aggregate:
|
||||
- { name: GigabitEthernet0/1, mtu: 256, description: test-interface-1 }
|
||||
- { name: GigabitEthernet0/2, mtu: 516, description: test-interface-2 }
|
||||
duplex: full
|
||||
speed: 100
|
||||
- { name: "{{ test_interface }}", mtu: 2000, description: test-interface-1 }
|
||||
- { name: "{{ test_interface2 }}", mtu: 2000, description: test-interface-2 }
|
||||
speed: 1000
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/1" 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 GigabitEthernet0/2" in result.commands'
|
||||
- '"speed 100" in result.commands'
|
||||
- '"interface {{ test_interface }}" in result.commands'
|
||||
- '"mtu 2000" in result.commands'
|
||||
- '"interface {{ test_interface2 }}" in result.commands'
|
||||
- '"description test-interface-2" in result.commands'
|
||||
- '"duplex full" in result.commands'
|
||||
- '"mtu 516" in result.commands'
|
||||
- '"mtu 2000" in result.commands'
|
||||
|
||||
- name: Add interface aggregate (idempotent)
|
||||
net_interface:
|
||||
aggregate:
|
||||
- { name: GigabitEthernet0/1, mtu: 256, description: test-interface-1 }
|
||||
- { name: GigabitEthernet0/2, mtu: 516, description: test-interface-2 }
|
||||
duplex: full
|
||||
speed: 100
|
||||
- { name: "{{ test_interface }}", mtu: 2000, description: test-interface-1 }
|
||||
- { name: "{{ test_interface2 }}", mtu: 2000, description: test-interface-2 }
|
||||
speed: 1000
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -166,39 +174,37 @@
|
|||
- name: Disable interface aggregate
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: GigabitEthernet0/1
|
||||
- name: GigabitEthernet0/2
|
||||
- { name: "{{ test_interface }}" }
|
||||
- { name: "{{ test_interface2 }}" }
|
||||
enabled: False
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/1" in result.commands'
|
||||
- '"interface {{ test_interface }}" in result.commands'
|
||||
- '"shutdown" in result.commands'
|
||||
- '"interface GigabitEthernet0/2" in result.commands'
|
||||
- '"interface {{ test_interface2 }}" in result.commands'
|
||||
- '"shutdown" in result.commands'
|
||||
|
||||
- name: Enable interface aggregate
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: GigabitEthernet0/1
|
||||
- name: GigabitEthernet0/2
|
||||
- { name: "{{ test_interface }}" }
|
||||
- { name: "{{ test_interface2 }}" }
|
||||
enabled: True
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"interface GigabitEthernet0/1" in result.commands'
|
||||
- '"interface {{ test_interface }}" in result.commands'
|
||||
- '"no shutdown" in result.commands'
|
||||
- '"interface GigabitEthernet0/2" in result.commands'
|
||||
- '"interface {{ test_interface2 }}" in result.commands'
|
||||
- '"no shutdown" in result.commands'
|
||||
|
||||
- name: loopback interface setup
|
||||
|
@ -216,7 +222,6 @@
|
|||
- name: Loopback10
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -232,7 +237,6 @@
|
|||
- name: Loopback10
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -248,7 +252,6 @@
|
|||
- name: Loopback10
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -1,14 +1,28 @@
|
|||
---
|
||||
- debug: msg="START net_interface ios/intent.yaml"
|
||||
|
||||
- name: Run show version
|
||||
ios_command:
|
||||
commands: show version
|
||||
authorize: yes
|
||||
register: show_version_result
|
||||
|
||||
- name: Set test interface to GigabitEthernet0/2 if we are on Cisco IOS
|
||||
set_fact: test_interface=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: Check intent arguments
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
state: up
|
||||
tx_rate: ge(0)
|
||||
rx_rate: le(0)
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -17,12 +31,11 @@
|
|||
|
||||
- name: Check intent arguments (failed condition)
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
state: down
|
||||
tx_rate: gt(0)
|
||||
rx_rate: lt(0)
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
|
@ -35,11 +48,10 @@
|
|||
|
||||
- name: Config + intent
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
enabled: False
|
||||
state: down
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -48,11 +60,10 @@
|
|||
|
||||
- name: Config + intent (fail)
|
||||
net_interface:
|
||||
name: GigabitEthernet0/2
|
||||
name: "{{ test_interface }}"
|
||||
enabled: False
|
||||
authorize: yes
|
||||
state: up
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
|
@ -61,17 +72,90 @@
|
|||
- "result.failed == true"
|
||||
- "'state eq(up)' in result.failed_conditions"
|
||||
|
||||
- name: Register show neighbors detail
|
||||
ios_command:
|
||||
commands:
|
||||
- show lldp neighbors
|
||||
authorize: yes
|
||||
register: show_lldp_neighbors_result
|
||||
|
||||
- block:
|
||||
- name: Check neighbors intent arguments
|
||||
net_interface:
|
||||
name: Gi0/0
|
||||
neighbors:
|
||||
- port: eth0
|
||||
host: netdev
|
||||
authorize: yes
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == false"
|
||||
|
||||
- name: Check neighbors intent arguments (failed condition)
|
||||
net_interface:
|
||||
name: Gi0/0
|
||||
neighbors:
|
||||
- port: dummy_port
|
||||
host: dummy_host
|
||||
authorize: yes
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == true"
|
||||
- "'host dummy_host' in result.failed_conditions"
|
||||
- "'port dummy_port' in result.failed_conditions"
|
||||
when: '"netdev" in show_lldp_neighbors_result.stdout'
|
||||
|
||||
- name: Aggregate config + intent (pass)
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: GigabitEthernet0/2
|
||||
- name: "{{ test_interface }}"
|
||||
enabled: True
|
||||
state: up
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == false"
|
||||
|
||||
- block:
|
||||
- name: Aggregate neighbors intent (pass)
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: Gi0/0
|
||||
neighbors:
|
||||
- port: eth0
|
||||
host: netdev
|
||||
authorize: yes
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == false"
|
||||
|
||||
- name: Aggregate neighbors intent (fail)
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: Gi0/0
|
||||
neighbors:
|
||||
- port: eth0
|
||||
host: netdev
|
||||
- port: dummy_port
|
||||
host: dummy_host
|
||||
authorize: yes
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == true"
|
||||
- "'host dummy_host' in result.failed_conditions"
|
||||
- "'port dummy_port' in result.failed_conditions"
|
||||
when: "'netdev' in show_lldp_neighbors_result.stdout"
|
||||
|
|
|
@ -5,7 +5,6 @@
|
|||
net_interface:
|
||||
name: GigabitEthernet0/0/0/2
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
|
||||
|
@ -14,7 +13,6 @@
|
|||
name: GigabitEthernet0/0/0/2
|
||||
description: test-interface-initial
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -27,7 +25,6 @@
|
|||
name: GigabitEthernet0/0/0/2
|
||||
description: test-interface-initial
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -42,7 +39,6 @@
|
|||
duplex: half
|
||||
mtu: 512
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -61,7 +57,6 @@
|
|||
duplex: full
|
||||
mtu: 256
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -80,8 +75,8 @@
|
|||
duplex: full
|
||||
mtu: 256
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == false'
|
||||
|
@ -90,7 +85,6 @@
|
|||
net_interface:
|
||||
name: GigabitEthernet0/0/0/2
|
||||
enabled: False
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -102,7 +96,6 @@
|
|||
net_interface:
|
||||
name: GigabitEthernet0/0/0/2
|
||||
enabled: True
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -115,7 +108,6 @@
|
|||
name: GigabitEthernet0/0/0/3
|
||||
description: test-interface-initial
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -138,7 +130,6 @@
|
|||
speed: 100
|
||||
duplex: full
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -162,7 +153,6 @@
|
|||
speed: 100
|
||||
duplex: full
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -176,7 +166,6 @@
|
|||
- name: GigabitEthernet0/0/0/2
|
||||
enabled: False
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -192,7 +181,6 @@
|
|||
- name: GigabitEthernet0/0/0/2
|
||||
enabled: True
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -207,7 +195,6 @@
|
|||
- name: GigabitEthernet0/0/0/4
|
||||
- name: GigabitEthernet0/0/0/5
|
||||
description: test-interface-initial
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- name: Create interface aggregate
|
||||
|
@ -218,7 +205,6 @@
|
|||
- name: GigabitEthernet0/0/0/5
|
||||
description: test_interface_2
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -233,7 +219,6 @@
|
|||
- name: GigabitEthernet0/0/0/4
|
||||
- name: GigabitEthernet0/0/0/5
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -248,7 +233,6 @@
|
|||
- name: GigabitEthernet0/0/0/4
|
||||
- name: GigabitEthernet0/0/0/5
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -7,7 +7,6 @@
|
|||
description: test_interface_5
|
||||
enabled: True
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- name: Check intent arguments
|
||||
|
@ -15,7 +14,6 @@
|
|||
name: GigabitEthernet0/0/0/5
|
||||
state: up
|
||||
delay: 20
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -26,7 +24,6 @@
|
|||
net_interface:
|
||||
name: GigabitEthernet0/0/0/5
|
||||
state: down
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
|
@ -41,7 +38,6 @@
|
|||
enabled: False
|
||||
state: down
|
||||
delay: 20
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -53,7 +49,6 @@
|
|||
name: GigabitEthernet0/0/0/5
|
||||
enabled: False
|
||||
state: up
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
|
@ -69,7 +64,6 @@
|
|||
enabled: True
|
||||
state: up
|
||||
delay: 20
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
|
|
|
@ -1,60 +1,85 @@
|
|||
---
|
||||
- debug: msg="START net_interface vyos/basic.yaml"
|
||||
|
||||
- name: Run vyos lsmod command
|
||||
vyos_command:
|
||||
commands:
|
||||
- lsmod
|
||||
register: lsmod_out
|
||||
|
||||
- name: Set up - delete interface
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: absent
|
||||
|
||||
- name: Configure interface params
|
||||
- name: Set up - Create interface
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: present
|
||||
description: test-interface
|
||||
speed: 100
|
||||
duplex: half
|
||||
mtu: 256
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"set interfaces ethernet eth1" in result.commands'
|
||||
- '"set interfaces ethernet eth1 description test-interface" in result.commands'
|
||||
- '"set interfaces ethernet eth1 speed 100" in result.commands'
|
||||
- '"set interfaces ethernet eth1 duplex half" in result.commands'
|
||||
- '"set interfaces ethernet eth1 mtu 256" in result.commands'
|
||||
|
||||
- name: Configure interface params (idempotent)
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: present
|
||||
description: test-interface
|
||||
speed: 100
|
||||
duplex: half
|
||||
mtu: 256
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == false'
|
||||
|
||||
- name: Change interface params
|
||||
- name: Configure interface params
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: present
|
||||
description: test-interface-1
|
||||
speed: 1000
|
||||
duplex: full
|
||||
mtu: 512
|
||||
speed: 100
|
||||
duplex: half
|
||||
mtu: 256
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"set interfaces ethernet eth1 description test-interface-1" in result.commands'
|
||||
- '"set interfaces ethernet eth1 speed 100" in result.commands'
|
||||
- '"set interfaces ethernet eth1 duplex half" in result.commands'
|
||||
- '"set interfaces ethernet eth1 mtu 256" in result.commands'
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Configure interface params (idempotent)
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: present
|
||||
description: test-interface-1
|
||||
speed: 100
|
||||
duplex: half
|
||||
mtu: 256
|
||||
register: result
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == false'
|
||||
when: "'virtio' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Change interface params
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: present
|
||||
description: test-interface-2
|
||||
speed: 1000
|
||||
duplex: full
|
||||
mtu: 512
|
||||
register: result
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- '"set interfaces ethernet eth1 description test-interface-2" in result.commands'
|
||||
- '"set interfaces ethernet eth1 speed 1000" in result.commands'
|
||||
- '"set interfaces ethernet eth1 duplex full" in result.commands'
|
||||
- '"set interfaces ethernet eth1 mtu 512" in result.commands'
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Disable interface
|
||||
net_interface:
|
||||
|
@ -111,6 +136,7 @@
|
|||
- { name: eth1, description: test-interface-1, speed: 100, duplex: half, mtu: 512}
|
||||
- { name: eth2, description: test-interface-2, speed: 1000, duplex: full, mtu: 256}
|
||||
register: result
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- assert:
|
||||
that:
|
||||
|
@ -123,6 +149,7 @@
|
|||
- '"set interfaces ethernet eth2 speed 1000" in result.commands'
|
||||
- '"set interfaces ethernet eth2 duplex full" in result.commands'
|
||||
- '"set interfaces ethernet eth2 mtu 256" in result.commands'
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Set interface on aggregate (idempotent)
|
||||
net_interface:
|
||||
|
@ -130,16 +157,19 @@
|
|||
- { name: eth1, description: test-interface-1, speed: 100, duplex: half, mtu: 512}
|
||||
- { name: eth2, description: test-interface-2, speed: 1000, duplex: full, mtu: 256}
|
||||
register: result
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == false'
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Disable interface on aggregate
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: eth1
|
||||
- name: eth2
|
||||
description: test-interface
|
||||
enabled: False
|
||||
register: result
|
||||
|
||||
|
@ -189,4 +219,5 @@
|
|||
that:
|
||||
- 'result.changed == false'
|
||||
|
||||
|
||||
- debug: msg="END net_interface vyos/basic.yaml"
|
||||
|
|
|
@ -1,30 +1,46 @@
|
|||
---
|
||||
- debug: msg="START net_interface vyos/intent.yaml"
|
||||
|
||||
- name: Run vyos lsmod command
|
||||
vyos_command:
|
||||
commands:
|
||||
- lsmod
|
||||
register: lsmod_out
|
||||
|
||||
- name: Setup (interface is up)
|
||||
net_interface:
|
||||
name: eth1
|
||||
enabled: True
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- name: Check intent arguments
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: up
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == false"
|
||||
|
||||
- name: Check lldp neighbors intent arguments
|
||||
net_interface:
|
||||
name: eth0
|
||||
neighbors:
|
||||
- port: eth0
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == false"
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Check intent arguments (failed condition)
|
||||
net_interface:
|
||||
name: eth1
|
||||
state: down
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
|
@ -33,12 +49,28 @@
|
|||
- "result.failed == true"
|
||||
- "'state eq(down)' in result.failed_conditions"
|
||||
|
||||
- name: Check lldp neighbors intent arguments (failed)
|
||||
net_interface:
|
||||
name: eth0
|
||||
neighbors:
|
||||
- port: dummy_port
|
||||
host: dummy_host
|
||||
ignore_errors: yes
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == true"
|
||||
- "'host dummy_host' in result.failed_conditions"
|
||||
- "'port dummy_port' in result.failed_conditions"
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Config + intent
|
||||
net_interface:
|
||||
name: eth1
|
||||
enabled: False
|
||||
state: down
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -50,7 +82,6 @@
|
|||
name: eth1
|
||||
enabled: False
|
||||
state: up
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
|
@ -65,10 +96,42 @@
|
|||
- name: eth1
|
||||
enabled: True
|
||||
state: up
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == false"
|
||||
|
||||
- name: Check lldp neighbors intent aggregate arguments
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: eth0
|
||||
neighbors:
|
||||
- port: eth0
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == false"
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
||||
- name: Check lldp neighbors intent aggregate arguments (failed)
|
||||
net_interface:
|
||||
aggregate:
|
||||
- name: eth0
|
||||
neighbors:
|
||||
- port: eth0
|
||||
- port: dummy_port
|
||||
host: dummy_host
|
||||
ignore_errors: yes
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.failed == true"
|
||||
- "'host dummy_host' in result.failed_conditions"
|
||||
- "'port dummy_port' in result.failed_conditions"
|
||||
when: "'virtio_net' not in lsmod_out.stdout[0]"
|
||||
|
|
|
@ -1,13 +1,12 @@
|
|||
---
|
||||
- debug: msg="START net_lldp junos/basic.yaml"
|
||||
|
||||
|
||||
- name: setup - remove lldp
|
||||
- name: setup - Disable lldp and remove it's configuration
|
||||
net_lldp:
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
|
||||
- name: configure lldp
|
||||
- name: Enable lldp
|
||||
net_lldp:
|
||||
state: present
|
||||
provider: "{{ netconf }}"
|
||||
|
@ -16,9 +15,8 @@
|
|||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'- disable;' in result.diff.prepared"
|
||||
|
||||
- name: configure lldp (idempotent)
|
||||
- name: Enable lldp (idempotent)
|
||||
net_lldp:
|
||||
state: present
|
||||
provider: "{{ netconf }}"
|
||||
|
@ -28,8 +26,74 @@
|
|||
that:
|
||||
- "result.changed == false"
|
||||
|
||||
- name: Disable lldp
|
||||
- name: configure lldp parameters and enable lldp
|
||||
net_lldp:
|
||||
interval: 10
|
||||
hold_multiplier: 5
|
||||
transmit_delay: 2
|
||||
state: present
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- result.diff.prepared | search("\+ *advertisement-interval 10")
|
||||
- result.diff.prepared | search("\+ *transmit-delay 2")
|
||||
- result.diff.prepared | search("\+ *hold-multiplier 5")
|
||||
|
||||
- name: configure lldp parameters and enable lldp(idempotent)
|
||||
net_lldp:
|
||||
interval: 10
|
||||
hold_multiplier: 5
|
||||
transmit_delay: 2
|
||||
state: present
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == false"
|
||||
|
||||
- name: configure lldp parameters and disable lldp
|
||||
net_lldp:
|
||||
interval: 10
|
||||
hold_multiplier: 5
|
||||
transmit_delay: 2
|
||||
state: disabled
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- result.diff.prepared | search("\+ *disable")
|
||||
- "'advertisement-interval 10;' not in result.diff.prepared"
|
||||
- "'transmit-delay 2;' not in result.diff.prepared"
|
||||
- "'hold-multiplier 5;' not in result.diff.prepared"
|
||||
|
||||
- name: configure lldp parameters and enable lldp
|
||||
net_lldp:
|
||||
interval: 10
|
||||
hold_multiplier: 5
|
||||
transmit_delay: 2
|
||||
state: enabled
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- result.diff.prepared | search("\- *disable")
|
||||
- "'advertisement-interval 10;' not in result.diff.prepared"
|
||||
- "'transmit-delay 2;' not in result.diff.prepared"
|
||||
- "'hold-multiplier 5;' not in result.diff.prepared"
|
||||
|
||||
- name: Remove lldp configuration and diable lldp
|
||||
net_lldp:
|
||||
interval: 10
|
||||
hold_multiplier: 5
|
||||
transmit_delay: 2
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
@ -37,9 +101,12 @@
|
|||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'+ disable;' in result.diff.prepared"
|
||||
- result.diff.prepared | search("\+ *disable")
|
||||
- result.diff.prepared | search("\- *advertisement-interval 10")
|
||||
- result.diff.prepared | search("\- *transmit-delay 2")
|
||||
- result.diff.prepared | search("\- *hold-multiplier 5")
|
||||
|
||||
- name: Disable lldp (idempotent)
|
||||
- name: Remove lldp (idempotent)
|
||||
net_lldp:
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
|
|
|
@ -5,7 +5,6 @@
|
|||
name: 172.16.0.1
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -20,7 +19,6 @@
|
|||
name: 172.16.0.1
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -33,7 +31,6 @@
|
|||
name: 172.16.0.1
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -47,7 +44,6 @@
|
|||
name: 172.16.0.1
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -60,7 +56,6 @@
|
|||
level: warnings
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -73,7 +68,6 @@
|
|||
dest: monitor
|
||||
level: debugging
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -87,7 +81,6 @@
|
|||
- { dest: console, level: warnings, state: absent }
|
||||
- { dest: monitor, level: debuggning, state: absent }
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -4,7 +4,6 @@
|
|||
dest: hostnameprefix
|
||||
name: 172.16.0.1
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -18,7 +17,6 @@
|
|||
dest: hostnameprefix
|
||||
name: 172.16.0.1
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -30,7 +28,6 @@
|
|||
dest: hostnameprefix
|
||||
name: 172.16.0.1
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -43,7 +40,6 @@
|
|||
dest: hostnameprefix
|
||||
name: 172.16.0.1
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -55,7 +51,6 @@
|
|||
dest: console
|
||||
level: warnings
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -67,7 +62,6 @@
|
|||
net_logging:
|
||||
dest: monitor
|
||||
level: debugging
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -80,7 +74,6 @@
|
|||
aggregate:
|
||||
- { dest: console, level: warnings, state: absent }
|
||||
- { dest: monitor, level: debuggning, state: absent }
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -1,21 +1,21 @@
|
|||
---
|
||||
- debug: msg="START net_logging junos/basic.yaml"
|
||||
|
||||
- name: setup - remove host logging
|
||||
- name: setup - remove file logging
|
||||
net_logging:
|
||||
dest: host
|
||||
name: 1.1.1.1
|
||||
dest: file
|
||||
name: test
|
||||
facility: pfe
|
||||
level: critical
|
||||
level: error
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
|
||||
- name: Create file logging
|
||||
net_logging:
|
||||
dest: host
|
||||
name: 1.1.1.1
|
||||
dest: file
|
||||
name: test_file
|
||||
facility: pfe
|
||||
level: critical
|
||||
level: error
|
||||
state: present
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
@ -29,16 +29,16 @@
|
|||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<name>1.1.1.1</name>' in config.xml"
|
||||
- "'<name>test_file</name>' in config.xml"
|
||||
- "'<name>pfe</name>' in config.xml"
|
||||
- "'<critical/>' in config.xml"
|
||||
- "'<error/>' in config.xml"
|
||||
|
||||
- name: Create file logging (idempotent)
|
||||
net_logging:
|
||||
dest: host
|
||||
name: 1.1.1.1
|
||||
dest: file
|
||||
name: test_file
|
||||
facility: pfe
|
||||
level: critical
|
||||
level: error
|
||||
state: present
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
@ -47,12 +47,59 @@
|
|||
that:
|
||||
- "result.changed == false"
|
||||
|
||||
- name: Deactivate logging configuration
|
||||
net_logging:
|
||||
dest: file
|
||||
name: test_file
|
||||
facility: pfe
|
||||
level: error
|
||||
state: present
|
||||
active: False
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Get running configuration
|
||||
junos_rpc:
|
||||
rpc: get-configuration
|
||||
provider: "{{ netconf }}"
|
||||
register: config
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<file inactive=\"inactive\">' in config.xml"
|
||||
- "'<contents inactive=\"inactive\">' in config.xml"
|
||||
|
||||
- name: Activate logging configuration
|
||||
net_logging:
|
||||
dest: file
|
||||
name: test_file
|
||||
facility: pfe
|
||||
level: error
|
||||
state: present
|
||||
active: True
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Get running configuration
|
||||
junos_rpc:
|
||||
rpc: get-configuration
|
||||
provider: "{{ netconf }}"
|
||||
register: config
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<name>test_file</name>' in config.xml"
|
||||
- "'<name>pfe</name>' in config.xml"
|
||||
- "'<error/>' in config.xml"
|
||||
|
||||
- name: Delete logging configuration
|
||||
net_logging:
|
||||
dest: host
|
||||
name: 1.1.1.1
|
||||
dest: file
|
||||
name: test_file
|
||||
facility: pfe
|
||||
level: critical
|
||||
level: error
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
@ -66,7 +113,7 @@
|
|||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<name>1.1.1.1</name>' not in config.xml"
|
||||
- "'<name>test_file</name>' not in config.xml"
|
||||
|
||||
- name: Configure console logging
|
||||
net_logging:
|
||||
|
@ -74,6 +121,7 @@
|
|||
facility: kernel
|
||||
level: emergency
|
||||
state: present
|
||||
active: True
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
|
@ -91,11 +139,12 @@
|
|||
- "'<emergency/>' in config.xml"
|
||||
|
||||
- name: Configure console logging (idempotent)
|
||||
junos_logging:
|
||||
net_logging:
|
||||
dest: console
|
||||
facility: kernel
|
||||
level: emergency
|
||||
state: present
|
||||
active: True
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
|
@ -103,6 +152,27 @@
|
|||
that:
|
||||
- "result.changed == false"
|
||||
|
||||
- name: Disable console logging
|
||||
net_logging:
|
||||
dest: console
|
||||
facility: kernel
|
||||
level: emergency
|
||||
state: present
|
||||
active: False
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Get running configuration
|
||||
junos_rpc:
|
||||
rpc: get-configuration
|
||||
provider: "{{ netconf }}"
|
||||
register: config
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<console inactive=\"inactive\">' in config.xml"
|
||||
|
||||
- name: Delete console logging
|
||||
net_logging:
|
||||
dest: console
|
||||
|
@ -123,17 +193,123 @@
|
|||
- "result.changed == true"
|
||||
- "'<console>' not in config.xml"
|
||||
|
||||
- name: Configure logging parameters
|
||||
net_logging:
|
||||
size: 65536
|
||||
files: 40
|
||||
rotate_frequency: 20
|
||||
state: present
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Get running configuration
|
||||
junos_rpc:
|
||||
rpc: get-configuration
|
||||
provider: "{{ netconf }}"
|
||||
register: config
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<size>64k</size>' in config.xml"
|
||||
- "'<files>40</files>' in config.xml"
|
||||
- "'<log-rotate-frequency>20</log-rotate-frequency>' in config.xml"
|
||||
|
||||
- name: Configure logging parameters (idempotent)
|
||||
net_logging:
|
||||
size: 65536
|
||||
files: 40
|
||||
rotate_frequency: 20
|
||||
state: present
|
||||
active: True
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == false"
|
||||
|
||||
- name: Disable logging parameters
|
||||
net_logging:
|
||||
size: 65536
|
||||
files: 40
|
||||
rotate_frequency: 20
|
||||
state: present
|
||||
active: False
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Get running configuration
|
||||
junos_rpc:
|
||||
rpc: get-configuration
|
||||
provider: "{{ netconf }}"
|
||||
register: config
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<size inactive=\"inactive\">64k</size>' in config.xml"
|
||||
- "'<files inactive=\"inactive\">40</files>' in config.xml"
|
||||
- "'<log-rotate-frequency inactive=\"inactive\">20</log-rotate-frequency>' in config.xml"
|
||||
|
||||
- name: Activate logging parameters
|
||||
net_logging:
|
||||
size: 65536
|
||||
files: 40
|
||||
rotate_frequency: 20
|
||||
state: present
|
||||
active: True
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Get running configuration
|
||||
junos_rpc:
|
||||
rpc: get-configuration
|
||||
provider: "{{ netconf }}"
|
||||
register: config
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<size>64k</size>' in config.xml"
|
||||
- "'<files>40</files>' in config.xml"
|
||||
- "'<log-rotate-frequency>20</log-rotate-frequency>' in config.xml"
|
||||
|
||||
- name: Delete logging parameters
|
||||
net_logging:
|
||||
size: 65536
|
||||
files: 40
|
||||
rotate_frequency: 20
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Get running configuration
|
||||
junos_rpc:
|
||||
rpc: get-configuration
|
||||
provider: "{{ netconf }}"
|
||||
register: config
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "result.changed == true"
|
||||
- "'<size>64k</size>' not in config.xml"
|
||||
- "'<files>40</files>' not in config.xml"
|
||||
- "'<log-rotate-frequency>20</log-rotate-frequency>' not in config.xml"
|
||||
|
||||
- name: Seup file logging using aggregate
|
||||
net_logging:
|
||||
aggregate:
|
||||
- {dest: file, name: test-1, facility: pfe, level: critical, state: absent}
|
||||
- {dest: file, name: test-2, facility: kernel, level: emergency, state: absent}
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- name: Configure file logging using aggregate
|
||||
net_logging:
|
||||
aggregate:
|
||||
- dest: file
|
||||
name: test-1
|
||||
facility: pfe
|
||||
level: critical
|
||||
- dest: file
|
||||
name: test-2
|
||||
facility: kernel
|
||||
level: emergency
|
||||
- {dest: file, name: test-1, facility: pfe, level: critical, active: True}
|
||||
- {dest: file, name: test-2, facility: kernel, level: emergency, active: True}
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
|
@ -145,7 +321,7 @@
|
|||
- result.diff.prepared | search("\+ *file test-2")
|
||||
- result.diff.prepared | search("\+ *kernel emergency")
|
||||
|
||||
- name: Delete file logging using aggregate
|
||||
- name: Deactivate file logging configuration using aggregate
|
||||
net_logging:
|
||||
aggregate:
|
||||
- dest: file
|
||||
|
@ -156,6 +332,40 @@
|
|||
name: test-2
|
||||
facility: kernel
|
||||
level: emergency
|
||||
active: False
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- result.diff.prepared | search("! *inactive[:] file test-1")
|
||||
- result.diff.prepared | search("! *inactive[:] pfe")
|
||||
- result.diff.prepared | search("! *inactive[:] file test-2")
|
||||
- result.diff.prepared | search("! *inactive[:] kernel")
|
||||
|
||||
- name: activate file logging configuration using aggregate
|
||||
net_logging:
|
||||
aggregate:
|
||||
- { dest: file, name: test-1, facility: pfe, level: critical }
|
||||
- { dest: file, name: test-2, facility: kernel, level: emergency }
|
||||
active: True
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == true'
|
||||
- result.diff.prepared | search("! *active[:] file test-1")
|
||||
- result.diff.prepared | search("! *active[:] pfe")
|
||||
- result.diff.prepared | search("! *active[:] file test-2")
|
||||
- result.diff.prepared | search("! *active[:] kernel")
|
||||
|
||||
- name: Delete file logging using aggregate
|
||||
net_logging:
|
||||
aggregate:
|
||||
- { dest: file, name: test-1, facility: pfe, level: critical }
|
||||
- { dest: file, name: test-2, facility: kernel, level: emergency }
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
@ -171,18 +381,12 @@
|
|||
- name: Delete file logging using aggregate (idempotent)
|
||||
net_logging:
|
||||
aggregate:
|
||||
- dest: file
|
||||
name: test-1
|
||||
facility: pfe
|
||||
level: critical
|
||||
- dest: file
|
||||
name: test-2
|
||||
facility: kernel
|
||||
level: emergency
|
||||
- { dest: file, name: test-1, facility: pfe, level: critical }
|
||||
- { dest: file, name: test-2, facility: kernel, level: emergency }
|
||||
state: absent
|
||||
provider: "{{ netconf }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- 'result.changed == false'
|
||||
- "result.changed == false"
|
||||
|
|
|
@ -5,7 +5,6 @@
|
|||
facility: all
|
||||
level: info
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -19,7 +18,6 @@
|
|||
facility: all
|
||||
level: info
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -33,7 +31,6 @@
|
|||
facility: all
|
||||
level: notice
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -48,7 +45,6 @@
|
|||
facility: all
|
||||
level: notice
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -62,7 +58,6 @@
|
|||
facility: all
|
||||
level: notice
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -77,7 +72,6 @@
|
|||
facility: all
|
||||
level: notice
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -90,7 +84,6 @@
|
|||
- { dest: file, name: test1, facility: all, level: info }
|
||||
- { dest: file, name: test2, facility: news, level: debug }
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -106,7 +99,6 @@
|
|||
- { dest: file, name: test1, facility: all, level: info, state: absent }
|
||||
- { dest: console, facility: daemon, level: warning }
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -122,7 +114,6 @@
|
|||
- { dest: console, facility: daemon, level: warning }
|
||||
- { dest: file, name: test2, facility: news, level: debug }
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -8,7 +8,6 @@
|
|||
next_hop: 10.0.0.8
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -23,7 +22,6 @@
|
|||
next_hop: 10.0.0.8
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -38,7 +36,6 @@
|
|||
admin_distance: 2
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -54,7 +51,6 @@
|
|||
admin_distance: 2
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -69,7 +65,6 @@
|
|||
admin_distance: 2
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -85,7 +80,6 @@
|
|||
admin_distance: 2
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -99,7 +93,6 @@
|
|||
- { prefix: 172.16.33.0, mask: 255.255.255.0, next_hop: 10.0.0.8 }
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -115,7 +108,6 @@
|
|||
- { prefix: 172.16.34.0, mask: 255.255.255.0, next_hop: 10.0.0.8 }
|
||||
state: present
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -131,7 +123,6 @@
|
|||
- { prefix: 172.16.34.0, mask: 255.255.255.0, next_hop: 10.0.0.8 }
|
||||
state: absent
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -4,7 +4,6 @@
|
|||
prefix: 172.24.0.0/24
|
||||
next_hop: 192.168.42.64
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -18,7 +17,6 @@
|
|||
mask: 24
|
||||
next_hop: 192.168.42.64
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -31,7 +29,6 @@
|
|||
next_hop: 192.168.42.64
|
||||
admin_distance: 1
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -46,7 +43,6 @@
|
|||
next_hop: 192.168.42.64
|
||||
admin_distance: 1
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -59,7 +55,6 @@
|
|||
next_hop: 192.168.42.64
|
||||
admin_distance: 1
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -73,7 +68,6 @@
|
|||
next_hop: 192.168.42.64
|
||||
admin_distance: 1
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -86,7 +80,6 @@
|
|||
- { prefix: 172.24.1.0/24, next_hop: 192.168.42.64 }
|
||||
- { prefix: 172.24.2.0, mask: 24, next_hop: 192.168.42.64 }
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -102,7 +95,6 @@
|
|||
- { prefix: 172.24.2.0/24, next_hop: 192.168.42.64, state: absent }
|
||||
- { prefix: 172.24.3.0/24, next_hop: 192.168.42.64 }
|
||||
state: present
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -117,7 +109,6 @@
|
|||
- { prefix: 172.24.1.0/24, next_hop: 192.168.42.64 }
|
||||
- { prefix: 172.24.3.0/24, next_hop: 192.168.42.64 }
|
||||
state: absent
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
- no ip name-server
|
||||
match: none
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
|
||||
|
||||
- name: configure name_servers
|
||||
net_system:
|
||||
|
@ -16,7 +16,6 @@
|
|||
- 2.2.2.2
|
||||
- 3.3.3.3
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -34,7 +33,6 @@
|
|||
- 2.2.2.2
|
||||
- 3.3.3.3
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -47,7 +45,6 @@
|
|||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -62,6 +59,5 @@
|
|||
- no ip domain lookup source-interface
|
||||
match: none
|
||||
authorize: yes
|
||||
provider: "{{ cli }}"
|
||||
|
||||
- debug: msg="END ios/set_name_servers.yaml"
|
||||
|
|
|
@ -8,7 +8,6 @@
|
|||
- no ip name-server 2.2.2.2
|
||||
- no ip name-server 3.3.3.3
|
||||
match: none
|
||||
provider: "{{ cli }}"
|
||||
|
||||
- name: configure name_servers
|
||||
net_system:
|
||||
|
@ -16,7 +15,6 @@
|
|||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
- 3.3.3.3
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -33,7 +31,6 @@
|
|||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
- 3.3.3.3
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -45,7 +42,6 @@
|
|||
name_servers:
|
||||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
provider: "{{ cli }}"
|
||||
|
||||
- name: configure name_servers
|
||||
nxos_system:
|
||||
net_system:
|
||||
name_servers:
|
||||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
|
@ -28,7 +28,7 @@
|
|||
- "'ip name-server 3.3.3.3' in result.commands"
|
||||
|
||||
- name: verify name_servers
|
||||
nxos_system:
|
||||
net_system:
|
||||
name_servers:
|
||||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
|
@ -41,7 +41,7 @@
|
|||
- result.changed == false
|
||||
|
||||
- name: remove one
|
||||
nxos_system:
|
||||
net_system:
|
||||
name_servers:
|
||||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
|
|
|
@ -8,15 +8,13 @@
|
|||
- no ip name-server 2.2.2.2
|
||||
- no ip name-server 3.3.3.3
|
||||
match: none
|
||||
provider: "{{ cli }}"
|
||||
|
||||
- name: configure name_servers
|
||||
vyos_system:
|
||||
net_system:
|
||||
name_servers:
|
||||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
- 3.3.3.3
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -28,12 +26,11 @@
|
|||
- "'ip name-server 3.3.3.3' in result.commands"
|
||||
|
||||
- name: verify name_servers
|
||||
vyos_system:
|
||||
net_system:
|
||||
name_servers:
|
||||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
- 3.3.3.3
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -41,11 +38,10 @@
|
|||
- result.changed == false
|
||||
|
||||
- name: remove one
|
||||
vyos_system:
|
||||
net_system:
|
||||
name_servers:
|
||||
- 1.1.1.1
|
||||
- 2.2.2.2
|
||||
provider: "{{ cli }}"
|
||||
register: result
|
||||
|
||||
- assert:
|
||||
|
@ -59,7 +55,6 @@
|
|||
lines:
|
||||
- no ip lookup source-interface
|
||||
match: none
|
||||
provider: "{{ cli }}"
|
||||
ignore_errors: yes
|
||||
# FIXME Copied from iosxr, not sure what we need here
|
||||
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
- debug: msg="START net_vlan eos/basic.yaml"
|
||||
|
||||
- name: setup - remove vlan
|
||||
eos_vlan:
|
||||
net_vlan:
|
||||
vlan_id: 4000
|
||||
name: test-vlan
|
||||
state: absent
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
|
||||
- name: setup - remove vrf
|
||||
eos_vrf:
|
||||
net_vrf:
|
||||
name: test
|
||||
state: absent
|
||||
authorize: yes
|
||||
|
|
Loading…
Reference in a new issue