X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=csit%2Flibraries%2FBGPSpeaker.robot;h=9b853bd4b38d130ce4ddac0e288a169af0693932;hb=97e57d489bfc88db0a70fcb04f145c4737d76b75;hp=c593890e8b2858d01eff39336fa6dacf9e25090c;hpb=790091e3341ce090a285b79f264ae30f0f170672;p=integration%2Ftest.git diff --git a/csit/libraries/BGPSpeaker.robot b/csit/libraries/BGPSpeaker.robot index c593890e8b..9b853bd4b3 100644 --- a/csit/libraries/BGPSpeaker.robot +++ b/csit/libraries/BGPSpeaker.robot @@ -1,7 +1,7 @@ *** Settings *** Documentation Robot keyword library (Resource) for handling the BGP speaker Python utilities. ... -... Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved. +... Copyright (c) 2015,2017 Cisco Systems, Inc. and others. All rights reserved. ... ... This program and the accompanying materials are made available under the ... terms of the Eclipse Public License v1.0 which accompanies this distribution, @@ -17,14 +17,20 @@ Documentation Robot keyword library (Resource) for handling the BGP speaker ... Aside BGP Speaker utility, there is also BGP Manager starting utilities in parallel. ... For purpose of dumping logs and killing, Manager behaves the same as Speaker. ... +... TODO: RemoteBash.robot contains logic which could be reused here. +... +... TODO: Update the following TODOs, as SSHKeywords.robot was introduced. ... TODO: The Utils.robot library has a "Run Command On Remote System" if we didn't ... want to make the assumption that an SSH connection was already open. ... alternative TODO: Explain that it is not worth to perform separate SSH logins. Library SSHLibrary -Resource ${CURDIR}/Utils.robot +Library RequestsLibrary +Resource RemoteBash.robot +Resource ../variables/Variables.robot *** Variables *** ${BGPSpeaker__OUTPUT_LOG} play.py.out +${PEER_URL} restconf/operational/bgp-rib:bgp-rib/rib/example-bgp-rib/peer/bgp:%2F%2F *** Keywords *** Start_BGP_Speaker @@ -37,10 +43,28 @@ Start_BGP_Speaker BuiltIn.Log ${command} ${output} = SSHLibrary.Write ${command} +Start_BGP_Speaker_And_Verify_Connected + [Arguments] ${arguments} ${session} ${speaker_ip}=${TOOLS_SYSTEM_IP} ${connected}=${True} + [Documentation] Start the BGP speaker python utility, and verifies it's connection. + ... We can change connected variable to false to verify Speaker did not connect. + Start_BGP_Speaker ${arguments} + ${message} BuiltIn.Wait_Until_Keyword_Succeeds 5x 2s Verify_BGP_Speaker_Connection ${session} ${speaker_ip} + ... ${connected} + [Return] ${message} + +Verify_BGP_Speaker_Connection + [Arguments] ${session} ${ip} ${connected}=${True} + [Documentation] Verifies peer's presence in bgp rib. + ${exp_status_code} BuiltIn.Set_Variable_If ${connected} ${200} ${404} + ${url} BuiltIn.Set_Variable ${PEER_URL}${ip} + ${response} RequestsLibrary.Get_Request ${session} ${url} + BuiltIn.Should_Be_Equal_As_Numbers ${exp_status_code} ${response.status_code} + [Return] ${response.content} + Start_BGP_Manager [Arguments] ${arguments} [Documentation] Start the BGP manager python utility. Redirect its error output to a log file. - ${command}= BuiltIn.Set_Variable python manage_play.py ${arguments} &> ${BGPSpeaker__OUTPUT_LOG} + ${command}= BuiltIn.Set_Variable python play.py ${arguments} &> ${BGPSpeaker__OUTPUT_LOG} BuiltIn.Log ${command} ${output}= SSHLibrary.Write ${command} @@ -56,10 +80,17 @@ Kill_BGP_Speaker [Documentation] Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout. ... Also dump the logs with the output the program produced. ... This keyword is also suitable for stopping BGP manager. - Utils.Write_Bare_Ctrl_C + RemoteBash.Write_Bare_Ctrl_C ${status} ${message} = BuiltIn.Run_Keyword_And_Ignore_Error SSHLibrary.Read_Until_Prompt Dump_BGP_Speaker_Logs # TODO: When Propagate_Failure is moved to better Resource, use it instead of the following. BuiltIn.Return_From_Keyword_If '${status}' == 'PASS' BuiltIn.Log ${message} BuiltIn.Fail The prompt was not seen within timeout period. + +Kill_All_BGP_Speakers + [Documentation] Kill all play.py processes. + ${command}= BuiltIn.Set_Variable ps axf | grep play.py | grep -v grep | awk '{print \"kill -9 \" $1}' | sh + SSHLibrary.Write ${command} + ${output}= SSHLibrary.Read_Until_Prompt + BuiltIn.Log ${output}