Library RequestsLibrary
Library SSHLibrary
Library XML
+Resource CompareStream.robot
Resource KarafKeywords.robot
+Resource SetupUtils.robot
Resource Utils.robot
*** Variables ***
${CONFIGURATION_XML} ${CURDIR}/../suites/topoprocessing/configuration.xml
${OPERATIONAL_XML} ${CURDIR}/../suites/topoprocessing/operational.xml
-${REMOTE_FILE} ${WORKSPACE}/${BUNDLEFOLDER}/etc/opendaylight/karaf/80-topoprocessing-config.xml
+${CONFIGURATION_CFG} ${CURDIR}/../suites/topoprocessing/configuration.cfg
+${OPERATIONAL_CFG} ${CURDIR}/../suites/topoprocessing/operational.cfg
+${REMOTE_XML_FILE} ${WORKSPACE}/${BUNDLEFOLDER}/etc/opendaylight/karaf/80-topoprocessing-config.xml
+${REMOTE_CFG_FILE} ${WORKSPACE}/${BUNDLEFOLDER}/etc/org.opendaylight.topoprocessing.cfg
+${OUTPUT_TOPO_NAME} topo:1
+${OVERLAY_TOPO_URL} ${TOPOLOGY_URL}/${OUTPUT_TOPO_NAME}
*** Keywords ***
Basic Request Put
[Arguments] ${request} ${overlay_topology_url}
- [Documentation] Test basic aggregation
+ [Documentation] Send a simple HTTP PUT request to Configurational datastore
${resp} Put Request session ${CONFIG_API}/${overlay_topology_url} data=${request}
Log ${CONFIG_API}/${overlay_topology_url}
- Should Be Equal As Strings ${resp.status_code} 200
+ Should Match "${resp.status_code}" "20?"
Wait For Karaf Log Correlation configuration successfully read
Wait For Karaf Log Transaction successfully written
-Basic Request Get And Test
- [Arguments] ${request} ${overlay_topology_url} ${should_contain} ${times}
- [Documentation] Test basic aggregation
+Basic Request Get
+ [Arguments] ${overlay_topology_url}
+ [Documentation] Send a simple HTTP GET request to a given URL
${resp} Get Request session ${OPERATIONAL_API}/${overlay_topology_url}
Should Be Equal As Strings ${resp.status_code} 200
- Should Contain X Times ${resp.content} ${should_contain} ${times}
[Return] ${resp}
-Send Basic Request And Test If Contain X Times
- [Arguments] ${request} ${overlay_topology_url} ${should_contain} ${times}
- [Documentation] Test basic aggregation
- Basic Request Put ${request} ${overlay_topology_url}
- ${resp} Wait Until Keyword Succeeds 40x 250ms Basic Request Get And Test ${request} ${overlay_topology_url}
- ... ${should_contain} ${times}
- Log ${resp.content}
+Send Basic Delete Request
+ [Arguments] ${url}
+ [Documentation] Sends a HTTP/DELETE request to a given URL
+ ${resp} Delete Request session ${CONFIG_API}/${url}
+ Log Deleting ${CONFIG_API}/${url}
+ [Return] ${resp}
+
+Delete Underlay Node
+ [Arguments] ${topology-id} ${node-id}
+ [Documentation] Deletes a node from an underlay topology
+ ${resp} Send Basic Delete Request ${TOPOLOGY_URL}/${topology-id}/node/${node-id}
+ [Return] ${resp}
+
+Delete Underlay Termination Point
+ [Arguments] ${topology-id} ${node-id} ${tp-id}
+ [Documentation] Deletes a termination point from an underlay topology
+ ${resp} Send Basic Delete Request ${TOPOLOGY_URL}/${topology-id}/node/${node-id}/termination-point/${tp-id}
+ [Return] ${resp}
+
+Delete Underlay Link
+ [Arguments] ${topology-id} ${link-id}
+ [Documentation] Deletes a link from an underlay topology
+ ${resp} Send Basic Delete Request ${TOPOLOGY_URL}/${topology-id}/link/${link-id}
[Return] ${resp}
Setup Environment
[Documentation] Setup karaf enviroment for following tests
Log ---- Setup Environment ----
+ SetupUtils.Setup_Utils_For_Setup_And_Teardown
Open Connection ${ODL_SYSTEM_IP}
Flexible Controller Login
- Put File ${CONFIGURATION_XML} ${REMOTE_FILE}
+ Put File ${CONFIGURATION_CFG} ${REMOTE_CFG_FILE}
Close Connection
- Issue Command On Karaf Console log:set DEBUG org.opendaylight.topoprocessing
- Install a Feature odl-restconf-noauth timeout=30
+ Wait Until Keyword Succeeds 2x 2s Issue Command On Karaf Console log:set DEBUG org.opendaylight.topoprocessing
Create Session session http://${ODL_SYSTEM_IP}:${RESTCONFPORT} auth=${AUTH} headers=${SEND_ACCEPT_XML_HEADERS}
- ${features} Issue Command On Karaf Console feature:list -i
- ${lines} Get Lines Containing String ${features} odl-topoprocessing-framework
- ${length} Get Length ${lines}
- Install a Feature odl-openflowplugin-nsf-model-li odl-topoprocessing-framework odl-topoprocessing-network-topology odl-topoprocessing-inventory odl-mdsal-models odl-ovsdb-southbound-impl timeout=120
- Run Keyword If ${length} == 0 Wait For Karaf Log Registering Topology Request Listener 60
Prepare New Feature Installation
Insert Underlay topologies
+Install Features
+ [Arguments] ${features} ${timeout}=180
+ [Documentation] Install features according to tested distribution
+ Install Features for Other Distributions ${features} ${timeout}
+
+Install Features for Beryllium Distribution
+ [Arguments] ${features} ${timeout}
+ [Documentation] Will wait for features to install only once per run
+ Install a Feature ${features} timeout=${timeout}
+ Set Global Variable If It Does Not Exist \${WAIT_FOR_FEATURES_TO_INSTALL} ${TRUE}
+ Run Keyword If ${WAIT_FOR_FEATURES_TO_INSTALL} Run Keywords Wait For Karaf Log Registering Topology Request Listener ${timeout}
+ ... AND Set Global Variable \${WAIT_FOR_FEATURES_TO_INSTALL} ${FALSE}
+
+Install Features for Other Distributions
+ [Arguments] ${features} ${timeout}
+ [Documentation] Will wait for features to install only if no topoprocessing feature was installed
+ ${installed_features} Issue Command On Karaf Console feature:list -i
+ ${lines} Get Lines Containing String ${installed_features} odl-topoprocessing-framework
+ ${length} Get Length ${lines}
+ Install a Feature ${features} timeout=${timeout}
+ Run Keyword If ${length} == 0 Wait For Karaf Log Registering Topology Request Listener ${timeout}
+
Clean Environment
[Documentation] Revert startup changes
Log ---- Clean Environment ----
Open Connection ${ODL_SYSTEM_IP}
Flexible Controller Login
- Put File ${OPERATIONAL_XML} ${REMOTE_FILE}
+ Put File ${OPERATIONAL_CFG} ${REMOTE_CFG_FILE}
Close Connection
Delete All Sessions
-Test Teardown
- [Arguments] ${overlay_topology}
+Delete Overlay Topology
[Documentation] Delete overlay topologies from datastore
+ Run Keyword If Test Failed Print Output Topo
Log ---- Test Teardown ----
- Log Deleting overlay topology from ${CONFIG_API}/${overlay_topology}
- ${resp} Delete Request session ${CONFIG_API}/${overlay_topology}
+ Log Deleting overlay topology from ${CONFIG_API}/${OVERLAY_TOPO_URL}
+ ${resp} Delete Request session ${CONFIG_API}/${OVERLAY_TOPO_URL}
Should Be Equal As Strings ${resp.status_code} 200
+Print Output Topo
+ [Documentation] Waits a while to allow any hanging transactions to finnish and then logs the output topology
+ Log ---- Output Topo Dump After Cooldown----
+ Sleep 2s
+ ${resp} Wait Until Keyword Succeeds 5x 250ms Basic Request Get ${OVERLAY_TOPO_URL}
+ Log ${resp.content}
+
+Refresh Underlay Topologies And Delete Overlay Topology
+ [Documentation] Deletes given overlay topology from datastore and overwrites the underlaying ones with initial topologies
+ Delete Overlay Topology
+ Insert Underlay Topologies
+
Prepare New Feature Installation
[Documentation] Clears karaf logs and CONFIGURATION datastore
${resp} Delete Request session ${CONFIG_API}/network-topology:network-topology
: FOR ${index} IN RANGE 1 7
\ ${resp} Put Request session ${CONFIG_API}/${TOPOLOGY_URL}/network-topo:${index} data=${NETWORK_UNDERLAY_TOPOLOGY_${index}}
\ Log ${resp.content}
- \ Should Be Equal As Strings ${resp.status_code} 200
+ \ Should Match "${resp.status_code}" "20?"
# Openflow underlay nodes
${resp} Put Request session ${CONFIG_API}/opendaylight-inventory:nodes data=${OPENFLOW_UNDERLAY_NODES}
Log ${resp.content}
- Should Be Equal As Strings ${resp.status_code} 200
+ Should Match "${resp.status_code}" "20?"
# Openflow underlay topologies
: FOR ${index} IN RANGE 1 7
\ ${resp} Put Request session ${CONFIG_API}/${TOPOLOGY_URL}/openflow-topo:${index} data=${OPENFLOW_UNDERLAY_TOPOLOGY_${index}}
\ Log ${resp.content}
- \ Should Be Equal As Strings ${resp.status_code} 200
+ \ Should Match "${resp.status_code}" "20?"
Issue Command On Karaf Console log:clear
Log ${resp.content}
[Return] ${request}
Create Isis Node
- [Arguments] ${node-id} ${router-id-ipv4}
+ [Arguments] ${node-id} ${ovs-version}=23 ${router-id-ipv4}=10.0.0.1
[Documentation] Create an isis node element with id and ip
${request} Set Element Text ${NODE_ISIS} ${node-id} xpath=.//node-id
+ ${request} Set Element Text ${request} ${ovs-version} xpath=.//ovs-version
${request} Set Element Text ${request} ${router-id-ipv4} xpath=.//igp-node-attributes/isis-node-attributes/ted/te-router-id-ipv4
${request} Element to String ${request}
- [Return ] ${request}
+ [Return] ${request}
Create Openflow Node
- [Arguments] ${node-id} ${ip-address}
+ [Arguments] ${node-id} ${ip-address}=10.0.0.1 ${serial-number}=27
[Documentation] Create an Openflow node element with id and ip
${request} Set Element Text ${NODE_OPENFLOW} ${node-id} xpath=.//id
${request} Set Element Text ${request} ${ip-address} xpath=.//ip-address
+ ${request} Set Element Text ${request} ${serial-number} xpath=.//serial-number
+ ${request} Element to String ${request}
+ [Return] ${request}
+
+Create OVSDB Termination Point
+ [Arguments] ${tp-id} ${ofport}
+ [Documentation] Create an OVSDB termination point element with id and port
+ ${request} Set Element Text ${TERMINATION_POINT_OVSDB} ${tp-id} xpath=.//tp-id
+ ${request} Set Element Text ${request} ${ofport} xpath=.//ofport
${request} Element to String ${request}
- [Return ] ${request}
\ No newline at end of file
+ [Return] ${request}
+
+Create Openflow Node Connector
+ [Arguments] ${nc-id} ${port-number}
+ [Documentation] Create an Openflow node connector element with id and port number
+ ${request} Set Element Text ${NODE_CONNECTOR_OPENFLOW} ${nc-id} xpath=.//id
+ ${request} Set Element Text ${request} ${port-number} xpath=.//port-number
+ ${request} Element to String ${request}
+ [Return] ${request}
+
+Create Link
+ [Arguments] ${link-id} ${source-node} ${dest-node} ${name} ${metric}
+ ${request} Set Element Text ${LINK} ${link-id} xpath=.//link-id
+ ${request} Set Element Text ${request} ${source-node} xpath=.//source/source-node
+ ${request} Set Element Text ${request} ${dest-node} xpath=.//destination/dest-node
+ ${request} Set Element Text ${request} ${name} xpath=.//igp-link-attributes/name
+ ${request} Set Element Text ${request} ${metric} xpath=.//igp-link-attributes/metric
+ ${request} Element to String ${request}
+ [Return] ${request}
+
+Extract Node from Topology
+ [Arguments] ${topology} ${supp_node_id}
+ [Documentation] Returns node that contains supporting node with ID specified in argument supp_node_id
+ ${xpath} Set Variable .//node/supporting-node[node-ref='${supp_node_id}']/..
+ ${node} Get Element ${topology} xpath=${xpath}
+ ${node} Element to String ${node}
+ [Return] ${node}
+
+Extract Termination Point from Topology
+ [Arguments] ${model} ${topology} ${topo_id} ${node_id} ${tp_id}
+ [Documentation] Returns termination point that contains supporting termination point from specified topology, node and with specified id
+ Check Supported Model ${model}
+ ${xpath} Set Variable If '${model}' == 'network-topology-model' or '${model}' == 'opendaylight-inventory-model' .//termination-point[tp-ref='/network-topology:network-topology/topology/${topo_id}/node/${node_id}/termination-point/${tp_id}'] .//termination-point/supporting-termination-point[tp-ref='${tp_id}']/..
+ ${tp} Get Element ${topology} xpath=${xpath}
+ ${tp} Element to String ${tp}
+ [Return] ${tp}
+
+Extract Link from Topology
+ [Arguments] ${model} ${topology} ${topo_id} ${link_id}
+ [Documentation] Returns link that contains supporting link
+ Check Supported Model ${model}
+ ${xpath} Set Variable If '${model}' == 'network-topology-model' or '${model}' == 'opendaylight-inventory-model' .//link/supporting-link[link-ref='/network-topology/topology/${topo_id}/link/${link_id}']/.. .//link/supporting-link[tp-ref='${tp_id}']/..
+ ${link} Get Element ${topology} xpath=${xpath}
+ ${link} Element to String ${link}
+ [Return] ${link}
+
+Check Supported Model
+ [Arguments] ${model}
+ [Documentation] Checks if model is supported.
+ Run Keyword If '${model}' != 'network-topology-model' and '${model}' != 'i2rs-model' and '${model}' != 'opendaylight-inventory-model' Fail Not supported model
+
+Check Aggregated Node in Topology
+ [Arguments] ${model} ${topology} ${tp_count} @{supp_node_ids}
+ [Documentation] Checks number of termination points and concrete supporting nodes in aggregated node and returns overlay node id. Model should be 'network-topology-model', 'opendaylight-inventory-model' or 'i2rs-model'.
+ Check Supported Model ${model}
+ ${node_id} Get From List ${supp_node_ids} 0
+ ${aggregated_node} Extract Node from Topology ${topology} ${node_id}
+ ${supp_node_count} Get Length ${supp_node_ids}
+ Should Contain X Times ${aggregated_node} <supporting-node> ${supp_node_count}
+ Should Contain X Times ${aggregated_node} <termination-point> ${tp_count}
+ Should Contain X Times ${aggregated_node} <tp-ref> ${tp_count}
+ : FOR ${supp_node_id} IN @{supp_node_ids}
+ \ Element Text Should Be ${aggregated_node} ${supp_node_id} xpath=.//supporting-node[node-ref='${supp_node_id}']/node-ref
+ ${overlay_node_id} Get Element Text ${aggregated_node} xpath=./node-id
+ [Return] ${overlay_node_id}
+
+Check Aggregated Termination Point in Node
+ [Arguments] ${model} ${topology} ${topology_id} ${node_id} ${tp_id} @{supp_tp_ids}
+ [Documentation] Checks supporting termination points in aggregated termination point. Model should be 'network-topology-model', 'opendaylight-inventory-model' or 'i2rs-model'.
+ Check Supported Model ${model}
+ ${tp} Extract Termination Point from Topology ${model} ${topology} ${topology_id} ${node_id} ${tp_id}
+ ${supp_tp_count} Get Length ${supp_tp_ids}
+ Should Contain X Times ${tp} <tp-ref> ${supp_tp_count}
+ : FOR ${supp_tp_id} IN @{supp_tp_ids}
+ \ Should Contain X Times ${tp} ${supp_tp_id}</tp-ref> 1
+
+Check Filtered Nodes in Topology
+ [Arguments] ${topology} ${tp_count} @{node_ids}
+ [Documentation] Checks nodes in filtered topology
+ : FOR ${node_id} IN @{node_ids}
+ \ Element Text Should Be ${topology} ${node_id} xpath=.//node/supporting-node[node-ref='${node_id}']/node-ref
+
+Check Filtered Termination Points in Node
+ [Arguments] ${topology} ${supp_node_id} @{supp_tp_ids}
+ [Documentation] Checks termination points in filtered topology
+ ${node} Extract Node from Topology ${topology} ${supp_node_id}
+ ${supp_tp_count} Get Length ${supp_tp_ids}
+ Should Contain X Times ${node} <supporting-node> 1
+ Should Contain X Times ${node} <termination-point> ${supp_tp_count}
+ Should Contain X Times ${node} <tp-ref> ${supp_tp_count}
+ : FOR ${supp_tp_id} IN @{supp_tp_ids}
+ \ Should Contain X Times ${node} ${supp_tp_id} 1
+
+Check Filtered Links In Topology
+ [Arguments] ${topology} @{supp_link_ids}
+ [Documentation] Checks links in filtered topology
+ : FOR ${supp_link_id} IN @{supp_link_ids}
+ \ Should Contain X Times ${topology} ${supp_link_id}</link-ref> 1
+
+Check Overlay Link Source And Destination
+ [Arguments] ${model} ${topology} ${topo_id} ${link_id} ${expected_source} ${expected_destination}
+ [Documentation] Checks if the overlay link's source and destination specified by a supporting link ref matches given source and destination
+ ${link} Extract Link from Topology ${model} ${topology} ${topo_id} ${link_id}
+ ${link_source} Get Element Text ${link} xpath=.//source-node
+ ${link_destination} Get Element Text ${link} xpath=.//dest-node
+ Should Be Equal As Strings ${link_source} ${expected_source}
+ Should Be Equal As Strings ${link_destination} ${expected_destination}
+
+Output Topo Should Be Complete
+ [Arguments] ${node_count}=-1 ${supporting-node_count}=-1 ${node-ref_count}=-1 ${tp_count}=-1 ${tp-ref_count}=-1 ${link_count}=-1
+ ... ${link-ref_count}=-1
+ [Documentation] Verifies that the output topology contains the expected amount of essential elements
+ ${resp} Wait Until Keyword Succeeds 5x 250ms Basic Request Get ${OVERLAY_TOPO_URL}
+ Should Contain ${resp.content} <topology-id>${OUTPUT_TOPO_NAME}</topology-id>
+ Run Keyword If ${node_count}>-1 Should Contain X Times ${resp.content} <node> ${node_count}
+ Run Keyword If ${supporting-node_count}>-1 Should Contain X Times ${resp.content} <supporting-node> ${supporting-node_count}
+ Run Keyword If ${node-ref_count}>-1 Should Contain X Times ${resp.content} <node-ref> ${node-ref_count}
+ Run Keyword If ${link_count}>-1 Should Contain X Times ${resp.content} <link> ${link_count}
+ Run Keyword If ${link-ref_count}>-1 Should Contain X Times ${resp.content} <link-ref> ${link-ref_count}
+ Run Keyword If ${tp_count}>-1 Should Contain X Times ${resp.content} <termination-point> ${tp_count}
+ Run Keyword If ${tp-ref_count}>-1 Should Contain X Times ${resp.content} <tp-ref> ${tp-ref_count}
+ Log ---- Output Topo ----
+ Log ${resp.content}
+ [Return] ${resp}
+
+Set Global Variable If It Does Not Exist
+ [Arguments] ${name} ${value}
+ ${status} ${message} = Run Keyword And Ignore Error Variable Should Exist ${name}
+ Run Keyword If "${status}" == "FAIL" Set Global Variable ${name} ${value}