From 498085ca750fda8e19379d45c05f1bda4df873e1 Mon Sep 17 00:00:00 2001 From: selias Date: Tue, 14 Jun 2016 17:25:39 +0200 Subject: Add Honeycomb notifications tests JIRA: CSIT-164 - add test cases for implemented notifications - add keywords used to receive and read notifications Change-Id: I3359aa83dca49ca362bf4406520ded1d36b67bda Signed-off-by: selias --- .../libraries/robot/honeycomb/notifications.robot | 77 ++++++++++++++++++++++ resources/libraries/robot/honeycomb/tap.robot | 1 - 2 files changed, 77 insertions(+), 1 deletion(-) create mode 100644 resources/libraries/robot/honeycomb/notifications.robot (limited to 'resources/libraries/robot') diff --git a/resources/libraries/robot/honeycomb/notifications.robot b/resources/libraries/robot/honeycomb/notifications.robot new file mode 100644 index 0000000000..ded8d3a2c0 --- /dev/null +++ b/resources/libraries/robot/honeycomb/notifications.robot @@ -0,0 +1,77 @@ +# Copyright (c) 2016 Cisco and/or its affiliates. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at: +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +*** Settings *** +| Library | resources.libraries.python.honeycomb.Notifications | ${hello} +| ... | ${subscription} +| Documentation | Keywords used to test Honeycomb notifications over Netconf. + +*** Variables *** +# hello message sent to Honeycomb through Netconf +| ${hello}= | +| ... | urn:ietf:params:netconf:base:1.0 +| ... | ]]>]]> +# rpc call to add a subscription to Netconf notifications +| ${subscription}= | +| ... | +| ... | honeycomb]]>]]> + +*** Keywords *** +| Notification listener is established +| | [Documentation] | Connects to Honeycomb notification service. +| | ... +| | ... | *Arguments:* +| | ... | - node - information about a DUT node. Type: dictionary +| | ... +| | ... | *Example:* +| | ... +| | ... | \| Notification listener is established \| ${nodes['DUT1']} \| +| | [Arguments] | ${node} +| | Create session | ${node} +| | Add notification listener + +| Honeycomb should send interface state notification +| | [Documentation] | Reads notification from Honeycomb and verifies\ +| | ... | notification type, interface name and interface admin-state. +| | ... +| | ... | *Arguments:* +| | ... | - interface - name of the affected interface. Type: string +| | ... | - state - expected state of interface, 'up' or 'down'. Type: string +| | ... +| | ... | *Example:* +| | ... +| | ... | \| Honeycomb should send interface state notification \ +| | ... | \| GigabitEthernet0/8/0 \| up \| +| | [Arguments] | ${interface} | ${state} +| | ${reply}= | Get notification +| | Should contain | ${reply} | ${interface} +| | Should contain | ${reply} | ${state} + +| Honeycomb should send interface deleted notification +| | [Documentation] | Reads notification from Honeycomb and verifies\ +| | ... | notification type and interface name. +| | ... +| | ... | *Arguments:* +| | ... | - interface - name of the deleted interface. Type: string +| | ... +| | ... | *Example:* +| | ... +| | ... | \| Honeycomb should send interface deleted notification \ +| | ... | \| temp_interface \| +| | [Arguments] | ${interface} +| | ${reply}= | Get notification +| | Should contain | ${reply} | ${interface} diff --git a/resources/libraries/robot/honeycomb/tap.robot b/resources/libraries/robot/honeycomb/tap.robot index f503b60090..2fffffa067 100644 --- a/resources/libraries/robot/honeycomb/tap.robot +++ b/resources/libraries/robot/honeycomb/tap.robot @@ -106,7 +106,6 @@ | | [Arguments] | ${node} | ${interface} | ${settings} | | ${vat_data}= | TAP Dump | ${node} | ${interface} | | Should be equal | ${vat_data['dev_name']} | ${settings['tap-name']} -| | ${vat_data}= | VPP Get interface data | ${node} # other settings not accessible through VAT commands | TAP configuration from Honeycomb should be empty -- cgit 1.2.3-korg