X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=csit%2Flibraries%2FSxpClusterLib.robot;h=86ac4e8bb5c62625b5231cac59e1215fe3324ae5;hb=a735c6ab080b16db82f58d867431474a029a4727;hp=57fbb8fcd5845fbde8d02cfe5d3451fed9ce22b9;hpb=ed99cd9b4ff437c955821f57639b051a7f919b8e;p=integration%2Ftest.git diff --git a/csit/libraries/SxpClusterLib.robot b/csit/libraries/SxpClusterLib.robot index 57fbb8fcd5..86ac4e8bb5 100644 --- a/csit/libraries/SxpClusterLib.robot +++ b/csit/libraries/SxpClusterLib.robot @@ -11,10 +11,9 @@ Resource ./SxpLib.robot @{SXP_PACKAGE} org.opendaylight.sxp ${DEVICE_SESSION} device_1 ${CONTROLLER_SESSION} ClusterManagement__session_1 -${SXP_LOG_LEVEL} INFO ${VIRTUAL_IP} ${TOOLS_SYSTEM_2_IP} ${VIRTUAL_IP_MASK} 255.255.255.0 -${VIRTUAL_INTERFACE} eth0 +${VIRTUAL_INTERFACE} dummy0 ${MAC_ADDRESS_TABLE} &{EMPTY} ${DEVICE_NODE_ID} ${TOOLS_SYSTEM_IP} ${CLUSTER_NODE_ID} ${TOOLS_SYSTEM_2_IP} @@ -25,7 +24,7 @@ Setup SXP Cluster Session [Documentation] Create sessions asociated with SXP cluster setup ClusterManagement.ClusterManagement_Setup SetupUtils.Setup_Utils_For_Setup_And_Teardown - SetupUtils.Setup_Logging_For_Debug_Purposes_On_List_Or_All ${SXP_LOG_LEVEL} ${SXP_PACKAGE} + SetupUtils.Setup_Logging_For_Debug_Purposes_On_List_Or_All DEBUG ${SXP_PACKAGE} Setup Device Session [Documentation] Create session on the SXP device @@ -39,7 +38,8 @@ Setup SXP Cluster Session With Device Clean SXP Cluster Session [Documentation] Clean sessions asociated with SXP cluster setup ClusterManagement.Flush_Iptables_From_List_Or_All - ClusterManagement.Check_Cluster_Is_In_Sync + BuiltIn.Wait Until Keyword Succeeds 60x 1s ClusterManagement.Verify_Members_Are_Ready member_index_list=${EMPTY} verify_cluster_sync=True verify_restconf=True + ... verify_system_status=False service_list=@{EMPTY} RequestsLibrary.Delete All Sessions SetupUtils.Setup_Logging_For_Debug_Purposes_On_List_Or_All INFO ${SXP_PACKAGE} @@ -53,27 +53,28 @@ Setup SXP Cluster [Arguments] ${peer_mode}=listener [Documentation] Setup and connect SXP cluster topology SxpLib.Add Node ${DEVICE_NODE_ID} session=${DEVICE_SESSION} + BuiltIn.Wait Until Keyword Succeeds 240x 1s SxpLib.Check Node Started ${DEVICE_NODE_ID} session=${DEVICE_SESSION} : FOR ${i} IN RANGE ${NUM_ODL_SYSTEM} \ SxpLib.Add Connection version4 ${peer_mode} ${ODL_SYSTEM_${i+1}_IP} 64999 node=${DEVICE_NODE_ID} \ ... session=${DEVICE_SESSION} ${cluster_mode} = Sxp.Get Opposing Mode ${peer_mode} SxpLib.Add Node ${INADDR_ANY} session=${CONTROLLER_SESSION} + BuiltIn.Wait Until Keyword Succeeds 240x 1s Check Cluster Node Started ${INADDR_ANY} ip=${EMPTY} SxpLib.Add Connection version4 ${cluster_mode} ${DEVICE_NODE_ID} 64999 ${INADDR_ANY} session=${CONTROLLER_SESSION} - BuiltIn.Wait Until Keyword Succeeds 1m 1x SxpLib.Check Node Started ${DEVICE_NODE_ID} session=${DEVICE_SESSION} - BuiltIn.Wait Until Keyword Succeeds 1m 1x Check Cluster Node started ${INADDR_ANY} ip=${EMPTY} - BuiltIn.Wait Until Keyword Succeeds 4m 1x Check Device is Connected ${DEVICE_NODE_ID} session=${DEVICE_SESSION} + BuiltIn.Wait Until Keyword Succeeds 480x 1s Check Device is Connected ${DEVICE_NODE_ID} session=${DEVICE_SESSION} Clean SXP Cluster [Documentation] Disconnect SXP cluster topology - ClusterManagement.Flush_Iptables_From_List_Or_All - : FOR ${i} IN RANGE ${NUM_ODL_SYSTEM} - \ BuiltIn.Wait Until Keyword Succeeds 240 1 ClusterManagement.Sync_Status_Should_Be_True ${i+1} SxpLib.Delete Node ${DEVICE_NODE_ID} session=${DEVICE_SESSION} - SxpLib.Delete Node ${INADDR_ANY} session=${CONTROLLER_SESSION} + BuiltIn.Wait Until Keyword Succeeds 240x 1s SxpLib.Check Node Stopped ${DEVICE_NODE_ID} session=${DEVICE_SESSION} + BuiltIn.Wait Until Keyword Succeeds 60x 1s SxpLib.Delete Node ${INADDR_ANY} session=${CONTROLLER_SESSION} + BuiltIn.Wait Until Keyword Succeeds 240x 1s SxpClusterLib.Check Cluster Node Stopped ${INADDR_ANY} ip=${EMPTY} -Check Cluster Node started +Check Cluster Node Started [Arguments] ${node} ${port}=64999 ${ip}=${node} [Documentation] Verify that SxpNode has data written to Operational datastore and Node is running on one of cluster nodes + ${resp} = RequestsLibrary.Get Request ${CONTROLLER_SESSION} /restconf/operational/network-topology:network-topology/topology/sxp/node/${node}/ + BuiltIn.Should Be Equal As Strings ${resp.status_code} 200 ${started} = BuiltIn.Set Variable ${False} : FOR ${i} IN RANGE ${NUM_ODL_SYSTEM} \ ${rc} = Utils.Run Command On Remote System ${ODL_SYSTEM_${i+1}_IP} netstat -tln | grep -q ${ip}:${port} && echo 0 || echo 1 ${ODL_SYSTEM_USER} ${ODL_SYSTEM_PASSWORD} @@ -81,6 +82,18 @@ Check Cluster Node started \ ${started} = BuiltIn.Set Variable If '${rc}' == '0' ${True} ${started} BuiltIn.Should Be True ${started} +Check Cluster Node Stopped + [Arguments] ${node} ${port}=64999 ${ip}=${node} + [Documentation] Verify that SxpNode has data removed from Operational datastore and Node is stopped + ${resp} = RequestsLibrary.Get Request ${CONTROLLER_SESSION} /restconf/operational/network-topology:network-topology/topology/sxp/node/${node}/ + BuiltIn.Should Be Equal As Strings ${resp.status_code} 404 + ${stopped} = BuiltIn.Set Variable ${False} + : FOR ${i} IN RANGE ${NUM_ODL_SYSTEM} + \ ${rc} = Utils.Run Command On Remote System ${ODL_SYSTEM_${i+1}_IP} netstat -tln | grep -q ${ip}:${port} && echo 0 || echo 1 ${ODL_SYSTEM_USER} ${ODL_SYSTEM_PASSWORD} + \ ... prompt=${ODL_SYSTEM_PROMPT} + \ ${stopped} = BuiltIn.Set Variable If '${rc}' == '1' ${True} ${stopped} + BuiltIn.Should Be True ${stopped} + Check Device is Connected [Arguments] ${node} ${version}=version4 ${port}=64999 ${session}=session [Documentation] Checks if SXP device is connected to the cluster. It means it has connection in state "on" with one of the cluster members. @@ -94,14 +107,14 @@ Check Device is Connected Check Cluster is Connected [Arguments] ${node} ${version}=version4 ${port}=64999 ${mode}=speaker ${session}=session - [Documentation] Get SXP connections from cluster and verify that they contain a connection to the device in state "on" + [Documentation] Get SXP connections of cluster ${node} and verify that they contain a connection to the device ${DEVICE_NODE_ID} in state "on" ${resp} = SxpLib.Get Connections node=${node} session=${session} SxpLib.Should Contain Connection ${resp} ${DEVICE_NODE_ID} ${port} ${mode} ${version} on Get Owner Controller [Arguments] ${running_member}=1 [Documentation] Find cluster controller that is marked as cluster owner by requesting ownership data from ${running_member} node of the cluster - ${owner} ${candidates} = BuiltIn.Wait_Until_Keyword_Succeeds 5x 2s ClusterManagement.Get_Owner_And_Successors_For_Device org.opendaylight.sxp.controller.boot.SxpControllerInstance + ${owner} ${candidates} = BuiltIn.Wait Until Keyword Succeeds 60x 1s ClusterManagement.Get_Owner_And_Successors_For_Device org.opendaylight.sxp.controller.boot.SxpControllerInstance ... Sxp ${running_member} [Return] ${owner} @@ -128,7 +141,7 @@ Map Followers To Mac Addresses Find Mac Address Of Ip Address [Arguments] ${ip} [Documentation] Finds out MAC-ADDRESS of specified IP by pinging it from TOOLS_SYSTEM machine - ${mac_address} = Utils.Run Command On Remote System ${TOOLS_SYSTEM_IP} ping -c 1 -W 1 ${ip} >/dev/null && arp -n | grep ${ip} | awk '{print $3}' ${TOOLS_SYSTEM_USER} ${TOOLS_SYSTEM_PASSWORD} + ${mac_address} = Utils.Run Command On Remote System And Log ${TOOLS_SYSTEM_IP} ping -c 10 -W 10 ${ip} >/dev/null && sudo ip neighbor show ${ip} | awk '{print $5}' ${TOOLS_SYSTEM_USER} ${TOOLS_SYSTEM_PASSWORD} [Return] ${mac_address} Ip Addres Should Not Be Routed To Follower @@ -158,7 +171,6 @@ Create Virtual Interface [Documentation] Create virtual interface on all of the cluster nodes : FOR ${i} IN RANGE ${NUM_ODL_SYSTEM} \ Utils.Run Command On Remote System ${ODL_SYSTEM_${i+1}_IP} sudo modprobe dummy ${ODL_SYSTEM_USER} ${ODL_SYSTEM_PASSWORD} - \ Utils.Run Command On Remote System ${ODL_SYSTEM_${i+1}_IP} sudo ip link set name ${VIRTUAL_INTERFACE} dev dummy0 ${ODL_SYSTEM_USER} ${ODL_SYSTEM_PASSWORD} \ Utils.Run Command On Remote System And Log ${ODL_SYSTEM_${i+1}_IP} sudo ip link show ${ODL_SYSTEM_USER} ${ODL_SYSTEM_PASSWORD} Delete Virtual Interface