nxos_logging implementation module (#26949)

* nxos_logging implementation module

Signed-off-by: Trishna Guha <trishnaguha17@gmail.com>

* pep8 fixes

* nxos_logging integration test

Signed-off-by: Trishna Guha <trishnaguha17@gmail.com>

* test typo fix

Signed-off-by: Trishna Guha <trishnaguha17@gmail.com>

* idempotent fix

* rename feature to facility

* make dest_group global var

* remove str from arg_spec
This commit is contained in:
Trishna Guha 2017-07-25 17:03:54 +05:30 committed by GitHub
commit e37e736ddb
11 changed files with 661 additions and 0 deletions

View file

@ -0,0 +1,2 @@
---
testcase: "*"

View file

@ -0,0 +1,2 @@
dependencies:
- prepare_nxos_tests

View file

@ -0,0 +1,15 @@
---
- name: collect all cli test cases
find:
paths: "{{ role_path }}/tests/cli"
patterns: "{{ testcase }}.yaml"
register: test_cases
- name: set test_items
set_fact: test_items="{{ test_cases.files | map(attribute='path') | list }}"
- name: run test case
include: "{{ test_case_to_run }}"
with_items: "{{ test_items }}"
loop_control:
loop_var: test_case_to_run

View file

@ -0,0 +1,3 @@
---
- { include: cli.yaml, tags: ['cli'] }
- { include: nxapi.yaml, tags: ['nxapi'] }

View file

@ -0,0 +1,28 @@
---
- name: collect all nxapi test cases
find:
paths: "{{ role_path }}/tests/nxapi"
patterns: "{{ testcase }}.yaml"
register: test_cases
- name: set test_items
set_fact: test_items="{{ test_cases.files | map(attribute='path') | list }}"
- name: enable nxapi
nxos_config:
lines:
- feature nxapi
- nxapi http port 80
provider: "{{ cli }}"
- name: run test case
include: "{{ test_case_to_run }}"
with_items: "{{ test_items }}"
loop_control:
loop_var: test_case_to_run
- name: disable nxapi
nxos_config:
lines:
- no feature nxapi
provider: "{{ cli }}"

View file

@ -0,0 +1,90 @@
---
- name: Set up console logging
nxos_logging:
dest: console
dest_level: 0
state: present
provider: "{{ cli }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"logging console 0" in result.commands'
- name: Set up console logging again (idempotent)
nxos_logging:
dest: console
dest_level: 0
state: present
provider: "{{ cli }}"
register: result
- assert:
that:
- 'result.changed == false'
- name: Delete/disable console logging
nxos_logging:
dest: console
dest_level: 0
state: absent
provider: "{{ cli }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"no logging console" in result.commands'
- name: Delete/disable console logging (idempotent)
nxos_logging:
dest: console
dest_level: 0
state: absent
provider: "{{ cli }}"
register: result
- assert:
that:
- 'result.changed == false'
- name: Logfile logging with level
nxos_logging:
dest: logfile
name: test
dest_level: 0
state: present
provider: "{{ cli }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"logging logfile test 0" in result.commands'
- name: Configure facility with level
nxos_logging:
facility: daemon
facility_level: 0
provider: "{{ cli }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"logging level daemon 0" in result.commands'
- name: remove logging as collection tearDown
nxos_logging:
aggregate:
- { dest: logfile, name: test, dest_level: 0, state: absent }
- { facility: daemon, facility_level: 0, state: absent }
provider: "{{ cli }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"no logging logfile" in result.commands'
- '"no logging level daemon" in result.commands'

View file

@ -0,0 +1,90 @@
---
- name: Set up console logging
nxos_logging:
dest: console
dest_level: 0
state: present
provider: "{{ nxapi }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"logging console 0" in result.commands'
- name: Set up console logging again (idempotent)
nxos_logging:
dest: console
dest_level: 0
state: present
provider: "{{ nxapi }}"
register: result
- assert:
that:
- 'result.changed == false'
- name: Delete/disable console logging
nxos_logging:
dest: console
dest_level: 0
state: absent
provider: "{{ nxapi }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"no logging console" in result.commands'
- name: Delete/disable console logging (idempotent)
nxos_logging:
dest: console
dest_level: 0
state: absent
provider: "{{ nxapi }}"
register: result
- assert:
that:
- 'result.changed == false'
- name: Logfile logging with level
nxos_logging:
dest: logfile
name: test
dest_level: 0
state: present
provider: "{{ nxapi }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"logging logfile test 0" in result.commands'
- name: Configure facility with level
nxos_logging:
facility: daemon
facility_level: 0
provider: "{{ nxapi }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"logging level daemon 0" in result.commands'
- name: remove logging as collection tearDown
nxos_logging:
aggregate:
- { dest: logfile, name: test, dest_level: 0, state: absent }
- { facility: daemon, facility_level: 0, state: absent }
provider: "{{ nxapi }}"
register: result
- assert:
that:
- 'result.changed == true'
- '"no logging logfile" in result.commands'
- '"no logging level daemon" in result.commands'