-# Copyright (c) 2017 Cisco and/or its affiliates.
+# Copyright (c) 2018 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:
from robot.api import logger
+from resources.libraries.python.topology import Topology
from resources.libraries.python.HTTPRequest import HTTPCodes
from resources.libraries.python.honeycomb.HoneycombSetup import HoneycombError
from resources.libraries.python.honeycomb.HoneycombUtil \
:type node: dict
:type path: str
:type data: dict
- :return: Content of response.
+ :returns: Content of response.
:rtype: bytearray
:raises HoneycombError: If the status code in response is not
200 = OK.
if special:
ip_version = "hc2vpp-ietf-{0}-unicast-routing:{0}".format(
ip_version)
- protocol = "vpp-routing-ra:vpp-protocol-attributes"
+ protocol = "vpp-routing:vpp-protocol-attributes"
else:
ip_version = ip_version
protocol = "vpp-protocol-attributes"
full_data = {
- "routing-protocol": [
+ "control-plane-protocol": [
{
"name": name,
"description": "hc2vpp-csit test route",
- "enabled": "true",
"type": "static",
protocol: {
"primary-vrf": vrf
]
}
- path = "/routing-protocol/{0}".format(name)
+ path = "/control-plane-protocol/hc2vpp-ietf-routing:static/{0}".format(
+ name)
return RoutingKeywords._set_routing_table_properties(
node, path, full_data)
:rtype: bytearray
"""
- path = "/routing-protocol/{0}".format(name)
+ path = "/control-plane-protocol/hc2vpp-ietf-routing:static/{0}".format(
+ name)
return RoutingKeywords._set_routing_table_properties(node, path)
@staticmethod
:raises HoneycombError: If the operation fails.
"""
- path = "/routing-protocol/{0}".format(name)
+ path = "/control-plane-protocol/hc2vpp-ietf-routing:static/{0}".format(
+ name)
status_code, resp = HcUtil.\
get_honeycomb_data(node, "oper_routing_table", path)
if status_code != HTTPCodes.OK:
raise HoneycombError(
"Not possible to get operational information about the "
- "classify tables. Status code: {0}.".format(status_code))
+ "routing tables. Status code: {0}.".format(status_code))
data = RoutingKeywords.clean_routing_oper_data(
- resp['routing-protocol'][0]['static-routes']
+ resp['control-plane-protocol'][0]['static-routes']
['hc2vpp-ietf-{0}-unicast-routing:{0}'.format(ip_version)]['route'])
return data
with VatTerminal(node) as vat:
vat.vat_terminal_exec_cmd("ip_fib_dump")
+
+ @staticmethod
+ def configure_interface_slaac(node, interface, slaac_data=None):
+ """Configure SLAAC on the specified interfaces.
+
+ :param node: Honeycomb node.
+ :param interface: Interface to configure SLAAC.
+ :param slaac_data: Dictionary of configurations to apply. \
+ If it is None then the existing configuration is removed.
+ :type node: dict
+ :type interface: str
+ :type slaac_data: dict of dicts
+ :returns: Content of response.
+ :rtype: bytearray
+ :raises HoneycombError: If RA could not be configured.
+ """
+
+ interface = Topology.convert_interface_reference(
+ node, interface, 'name')
+ interface = interface.replace('/', '%2F')
+ path = 'interface/' + interface + '/ipv6/ipv6-router-advertisements'
+
+ if not slaac_data:
+ status_code, _ = HcUtil.delete_honeycomb_data(
+ node, 'config_slaac', path)
+ else:
+ data = {
+ 'ipv6-router-advertisements': slaac_data
+ }
+
+ status_code, _ = HcUtil.put_honeycomb_data(
+ node, 'config_slaac', data, path)
+
+ if status_code not in (HTTPCodes.OK, HTTPCodes.ACCEPTED):
+ raise HoneycombError(
+ 'Configuring SLAAC failed. Status code:{0}'.format(status_code))
+
+ @staticmethod
+ def get_interface_slaac_oper_data(node, interface):
+ """Get operational data about SLAAC table present on the node.
+
+ :param node: Honeycomb node.
+ :param interface: Interface SLAAC data are retrieved from.
+ :type node: dict
+ :type interface: str
+ :returns: dict of SLAAC operational data.
+ :rtype: dict
+ :raises HoneycombError: If status code differs from successful.
+ """
+ interface = Topology.convert_interface_reference(
+ node, interface, 'name')
+ interface = interface.replace('/', '%2F')
+ path = 'interface/' + interface + '/ipv6/ipv6-router-advertisements'
+
+ status_code, resp = HcUtil.\
+ get_honeycomb_data(node, "config_slaac", path)
+
+ if status_code != HTTPCodes.OK:
+ raise HoneycombError(
+ "Not possible to get operational information about SLAAC. "
+ "Status code: {0}.".format(status_code))
+ try:
+ dict_of_str = resp[
+ 'hc2vpp-ietf-ipv6-unicast-routing:ipv6-router-advertisements']
+ return {k: str(v) for k, v in dict_of_str.items()}
+ except (KeyError, TypeError):
+ return {}
+
+ @staticmethod
+ def configure_policer(node, policy_name, policer_data=None):
+ """Configure Policer on the specified node.
+
+ :param node: Honeycomb node.
+ :param policer_data: Dictionary of configurations to apply. \
+ If it is None then the existing configuration is removed.
+ :type node: dict
+ :type policer_data: dict
+ :returns: Content of response.
+ :rtype: bytearray
+ :raises HoneycombError: If policer could not be configured.
+ """
+
+ path = '/' + policy_name
+
+ if not policer_data:
+ status_code, _ = HcUtil.delete_honeycomb_data(
+ node, 'config_policer', path)
+ else:
+ data = {
+ 'policer': policer_data
+ }
+
+ status_code, _ = HcUtil.put_honeycomb_data(
+ node, 'config_policer', data, path)
+
+ if status_code not in (HTTPCodes.OK, HTTPCodes.ACCEPTED):
+ raise HoneycombError(
+ 'Configuring policer failed. Status code:{0}'\
+ .format(status_code))
+
+ @staticmethod
+ def get_policer_oper_data(node, policy_name):
+ """Get operational data about Policer on the node.
+
+ :param node: Honeycomb node.
+ :type node: dict
+ :returns: dict of Policer operational data.
+ :rtype: dict
+ :raises HoneycombError: If status code differs from successful.
+ """
+
+ path = '/' + policy_name
+
+ status_code, resp = HcUtil.\
+ get_honeycomb_data(node, "oper_policer", path)
+
+ if status_code != HTTPCodes.OK:
+ raise HoneycombError(
+ "Not possible to get operational information about Policer. "
+ "Status code: {0}.".format(status_code))
+ try:
+ return resp['policer']
+ except (KeyError, TypeError):
+ return {}