mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-10-24 04:54:00 -07:00
added junos_smoke tests (#37216)
* added junos_smoke tests * enable check mode test * fix check mode test
This commit is contained in:
parent
38fa1d0b15
commit
0bd2cd4394
6 changed files with 183 additions and 0 deletions
3
test/integration/targets/junos_smoke/defaults/main.yaml
Normal file
3
test/integration/targets/junos_smoke/defaults/main.yaml
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
---
|
||||||
|
testcase: "*"
|
||||||
|
test_items: []
|
2
test/integration/targets/junos_smoke/meta/main.yml
Normal file
2
test/integration/targets/junos_smoke/meta/main.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
dependencies:
|
||||||
|
- prepare_junos_tests
|
2
test/integration/targets/junos_smoke/tasks/main.yaml
Normal file
2
test/integration/targets/junos_smoke/tasks/main.yaml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
---
|
||||||
|
- { include: netconf.yaml, tags: ['netconf'] }
|
21
test/integration/targets/junos_smoke/tasks/netconf.yaml
Normal file
21
test/integration/targets/junos_smoke/tasks/netconf.yaml
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
- name: collect netconf test cases
|
||||||
|
find:
|
||||||
|
paths: "{{ role_path }}/tests/netconf"
|
||||||
|
patterns: "{{ testcase }}.yaml"
|
||||||
|
connection: local
|
||||||
|
register: test_cases
|
||||||
|
|
||||||
|
- name: set test_items
|
||||||
|
set_fact: test_items="{{ test_cases.files | map(attribute='path') | list }}"
|
||||||
|
|
||||||
|
- name: run test case (connection=netconf)
|
||||||
|
include: "{{ test_case_to_run }} ansible_connection=netconf"
|
||||||
|
with_items: "{{ test_items }}"
|
||||||
|
loop_control:
|
||||||
|
loop_var: test_case_to_run
|
||||||
|
|
||||||
|
- name: run test case (connection=local)
|
||||||
|
include: "{{ test_case_to_run }} ansible_connection=local"
|
||||||
|
with_items: "{{ test_items }}"
|
||||||
|
loop_control:
|
||||||
|
loop_var: test_case_to_run
|
|
@ -0,0 +1,56 @@
|
||||||
|
---
|
||||||
|
# junos interface -> remove_default_spec() conditional()
|
||||||
|
- debug: msg="START junos_interface netconf/common_utils.yaml on connection={{ ansible_connection }}"
|
||||||
|
|
||||||
|
- name: get facts
|
||||||
|
junos_facts:
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
|
||||||
|
- name: Define interface name for vSRX
|
||||||
|
set_fact:
|
||||||
|
intf_name: pp0
|
||||||
|
when: result['ansible_facts']['ansible_net_model'] is search("vSRX*")
|
||||||
|
|
||||||
|
- name: Define interface name for vsrx
|
||||||
|
set_fact:
|
||||||
|
intf_name: pp0
|
||||||
|
when: result['ansible_facts']['ansible_net_model'] is search("vsrx")
|
||||||
|
|
||||||
|
- name: Define interface name for vQFX
|
||||||
|
set_fact:
|
||||||
|
intf_name: gr-0/0/0
|
||||||
|
when: result['ansible_facts']['ansible_net_model'] is search("vqfx*")
|
||||||
|
|
||||||
|
- name: Check intent arguments
|
||||||
|
junos_interface:
|
||||||
|
name: "{{ intf_name }}"
|
||||||
|
state: up
|
||||||
|
tx_rate: ge(0)
|
||||||
|
rx_rate: le(0)
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- "result.failed == false"
|
||||||
|
|
||||||
|
- name: Check intent arguments (failed condition)
|
||||||
|
junos_interface:
|
||||||
|
name: "{{ intf_name }}"
|
||||||
|
state: down
|
||||||
|
tx_rate: gt(0)
|
||||||
|
rx_rate: lt(0)
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
ignore_errors: yes
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- "result.failed == true"
|
||||||
|
- "'state eq(down)' in result.failed_conditions"
|
||||||
|
- "'tx_rate gt(0)' in result.failed_conditions"
|
||||||
|
- "'rx_rate lt(0)' in result.failed_conditions"
|
||||||
|
|
||||||
|
- debug: msg="END junos_interface netconf/common_utils.yaml on connection={{ ansible_connection }}"
|
|
@ -0,0 +1,99 @@
|
||||||
|
---
|
||||||
|
- debug: msg="START netconf/module_utils_junos.yaml on connection={{ ansible_connection }}"
|
||||||
|
|
||||||
|
# hit get_capabilities()
|
||||||
|
|
||||||
|
- name: get output for single command
|
||||||
|
junos_command:
|
||||||
|
commands: ['show version']
|
||||||
|
format: json
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- "result.changed == false"
|
||||||
|
- "result.stdout is defined"
|
||||||
|
- "result.stdout_lines is defined"
|
||||||
|
|
||||||
|
# hit commit_configuration()
|
||||||
|
- name: setup - remove login banner
|
||||||
|
junos_banner:
|
||||||
|
banner: login
|
||||||
|
state: absent
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
|
||||||
|
- name: Create login banner
|
||||||
|
junos_banner:
|
||||||
|
banner: login
|
||||||
|
text: this is my login banner
|
||||||
|
state: present
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Get running configuration
|
||||||
|
junos_rpc:
|
||||||
|
rpc: get-configuration
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: config
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- "result.changed == true"
|
||||||
|
- "'<message>this is my login banner</message>' in config.xml"
|
||||||
|
|
||||||
|
# hit discard_changes()
|
||||||
|
- name: check mode
|
||||||
|
junos_banner:
|
||||||
|
banner: login
|
||||||
|
text: this is not the banner you're looking for
|
||||||
|
state: present
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: result
|
||||||
|
check_mode: yes
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- "result.changed == true"
|
||||||
|
- "result.failed == false"
|
||||||
|
|
||||||
|
|
||||||
|
# hit field_top in map_obj_to_ele
|
||||||
|
- name: setup - remove interface address
|
||||||
|
net_l3_interface:
|
||||||
|
name: ge-0/0/1
|
||||||
|
ipv4: 1.1.1.1
|
||||||
|
ipv6: fd5d:12c9:2201:1::1
|
||||||
|
state: absent
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
|
||||||
|
- name: Configure interface address using platform agnostic module
|
||||||
|
net_l3_interface:
|
||||||
|
name: ge-0/0/1
|
||||||
|
ipv4: 1.1.1.1
|
||||||
|
ipv6: fd5d:12c9:2201:1::1
|
||||||
|
state: present
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: result
|
||||||
|
|
||||||
|
- name: Get running configuration
|
||||||
|
junos_rpc:
|
||||||
|
rpc: get-configuration
|
||||||
|
provider: "{{ netconf }}"
|
||||||
|
register: config
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- "result.changed == true"
|
||||||
|
- "'<name>1.1.1.1/32</name>' in config.xml"
|
||||||
|
- "'<name>fd5d:12c9:2201:1::1/128</name>' in config.xml"
|
||||||
|
- result.diff.prepared is search("\+ *address 1.1.1.1/32")
|
||||||
|
- result.diff.prepared is search("\+ *address fd5d:12c9:2201:1::1/128")
|
||||||
|
|
||||||
|
- name: teardown - remove interface address
|
||||||
|
net_l3_interface:
|
||||||
|
name: ge-0/0/1
|
||||||
|
ipv4: 1.1.1.1
|
||||||
|
ipv6: fd5d:12c9:2201:1::1
|
||||||
|
state: absent
|
||||||
|
provider: "{{ netconf }}"
|
Loading…
Add table
Add a link
Reference in a new issue