2 Documentation Functional test suite for bgp - l3vpn-ipv4
4 ... Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.
6 ... This program and the accompanying materials are made available under the
7 ... terms of the Eclipse Public License v1.0 which accompanies this distribution,
8 ... and is available at http://www.eclipse.org/legal/epl-v10.html
10 ... This suite tests advertising and receiveing routes with l3vpn content.
11 ... It uses odl and exabgp as bgp peers. Routes advertized from odl
12 ... are configured via application peer. Routes advertised from exabgp is
13 ... statically configured in exabgp config file.
14 Suite Setup Start_Suite
15 Suite Teardown Stop_Suite
16 Library RequestsLibrary
18 Variables ${CURDIR}/../../../variables/Variables.py
19 Resource ${CURDIR}/../../../libraries/Utils.robot
20 Resource ${CURDIR}/../../../libraries/SetupUtils.robot
21 Resource ${CURDIR}/../../../libraries/TemplatedRequests.robot
22 Resource ${CURDIR}/../../../libraries/KarafKeywords.robot
23 Resource ${CURDIR}/../../../libraries/SSHKeywords.robot
24 Library ${CURDIR}/../../../libraries/norm_json.py
25 Library ${CURDIR}/../../../libraries/BgpRpcClient.py ${TOOLS_SYSTEM_IP}
29 ${DEVICE_NAME} controller-config
30 ${BGP_PEER_NAME} example-bgp-peer
31 ${RIB_INSTANCE} example-bgp-rib
32 ${APP_PEER_NAME} example-bgp-peer-app
33 ${CMD} env exabgp.tcp.port=1790 exabgp --debug
34 ${BGP_VAR_FOLDER} ${CURDIR}/../../../variables/bgpfunctional
35 ${BGP_L3VPN_DIR} ${BGP_VAR_FOLDER}/l3vpn_ipv4
36 ${DEFAUTL_EXA_CFG} exa.cfg
37 ${L3VPN_EXA_CFG} bgp-l3vpn-ipv4.cfg
38 ${L3VPN_RSPEMPTY} ${BGP_L3VPN_DIR}/bgp-l3vpn-ipv4-empty.json
39 ${L3VPN_RSP} ${BGP_L3VPN_DIR}/bgp-l3vpn-ipv4.json
40 ${L3VPN_URL} /restconf/operational/bgp-rib:bgp-rib/rib/example-bgp-rib/loc-rib/tables/bgp-types:ipv4-address-family/bgp-types:mpls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
41 ${CONFIG_SESSION} config-session
42 ${EXARPCSCRIPT} ${CURDIR}/../../../../tools/exabgp_files/exarpc.py
43 ${PEER_CHECK_URL} /restconf/operational/bgp-rib:bgp-rib/rib/example-bgp-rib/peer/bgp:%2F%2F
44 ${DEFAULT_BGPCEP_LOG_LEVEL} INFO
48 [Documentation] Configures bgp application peer
49 KarafKeywords.Log_Testcase_Start_To_Controller_Karaf
50 &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} APP_PEER_NAME=${APP_PEER_NAME} RIB_INSTANCE_NAME=${RIB_INSTANCE} APP_PEER_ID=${ODL_SYSTEM_IP}
51 TemplatedRequests.Put_As_Xml_Templated ${BGP_VAR_FOLDER}/app_peer mapping=${mapping} session=${CONFIG_SESSION}
53 Reconfigure_ODL_To_Accept_Connection
54 [Documentation] Configures BGP peer module with initiate-connection set to false.
55 KarafKeywords.Log_Testcase_Start_To_Controller_Karaf
56 &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} BGP_NAME=${BGP_PEER_NAME} IP=${TOOLS_SYSTEM_IP} HOLDTIME=${HOLDTIME} PEER_PORT=${BGP_TOOL_PORT}
57 ... INITIATE=false RIB_INSTANCE_NAME=${RIB_INSTANCE}
58 TemplatedRequests.Put_As_Xml_Templated ${BGP_VAR_FOLDER}/bgp_peer mapping=${mapping} session=${CONFIG_SESSION}
61 [Documentation] Testing mpls vpn ipv4 routes reported to odl from exabgp
62 [Setup] Setup_Testcase ${L3VPN_EXA_CFG} ${L3VPN_URL} ${L3VPN_RSPEMPTY}
63 BuiltIn.Wait_Until_Keyword_Succeeds 15s 1s Verify Reported Data ${L3VPN_URL} ${L3VPN_RSP}
64 [Teardown] Teardown_Testcase ${L3VPN_URL} ${L3VPN_RSPEMPTY}
67 [Documentation] Testing mpls vpn ipv4 routes reported from odl to exabgp
68 [Setup] Start_Tool_And_Verify_Connected ${DEFAUTL_EXA_CFG}
69 BgpRpcClient.exa_clean_update_message
70 &{mapping} BuiltIn.Create_Dictionary BGP_PEER_IP=${TOOLS_SYSTEM_IP}
71 TemplatedRequests.Post_As_Xml_Templated ${BGP_L3VPN_DIR}/route mapping=${mapping} session=${CONFIG_SESSION}
72 BuiltIn.Wait_Until_Keyword_Succeeds 5x 2s Verify_Tool_Received_Update ${BGP_L3VPN_DIR}/route/exa-expected.json
73 [Teardown] Remove_Route_And_Stop_Tool
75 Delete_Bgp_Peer_Configuration
76 [Documentation] Revert the BGP configuration to the original state: without any configured peers.
77 KarafKeywords.Log_Testcase_Start_To_Controller_Karaf
78 &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} BGP_NAME=${BGP_PEER_NAME}
79 TemplatedRequests.Delete_Templated ${BGP_VAR_FOLDER}/bgp_peer mapping=${mapping} session=${CONFIG_SESSION}
82 [Documentation] Revert the BGP configuration to the original state: without application peer
83 KarafKeywords.Log_Testcase_Start_To_Controller_Karaf
84 &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} APP_PEER_NAME=${APP_PEER_NAME}
85 TemplatedRequests.Delete_Templated ${BGP_VAR_FOLDER}/app_peer mapping=${mapping} session=${CONFIG_SESSION}
89 [Documentation] Suite setup keyword
90 SetupUtils.Setup_Utils_For_Setup_And_Teardown
91 ${tools_system_conn_id}= SSHLibrary.Open_Connection ${TOOLS_SYSTEM_IP} prompt=${DEFAULT_LINUX_PROMPT} timeout=6s
92 Builtin.Set_Suite_Variable ${tools_system_conn_id}
93 Utils.Flexible_Mininet_Login ${TOOLS_SYSTEM_USER}
94 SSHKeywords.Virtual_Env_Create
95 SSHKeywords.Virtual_Env_Install_Package exabgp==3.4.16
96 RequestsLibrary.Create_Session ${CONFIG_SESSION} http://${ODL_SYSTEM_IP}:${RESTCONFPORT} auth=${AUTH}
98 KarafKeywords.Set_Bgpcep_Log_Levels # ${DEFAULT_BGPCEP_LOG_LEVEL} is applied by default
101 [Documentation] Suite teardown keyword
102 SSHKeywords.Virtual_Env_Delete
103 SSHLibrary.Close_All_Connections
104 RequestsLibrary.Delete_All_Sessions
107 [Documentation] Uploads exabgp config files and needed scripts
108 SSHLibrary.Put_File ${BGP_VAR_FOLDER}/${DEFAUTL_EXA_CFG} .
109 SSHLibrary.Put_File ${BGP_L3VPN_DIR}/${L3VPN_EXA_CFG} .
110 SSHLibrary.Put_File ${EXARPCSCRIPT} .
111 @{cfgfiles}= SSHLibrary.List_Files_In_Directory . *.cfg
112 : FOR ${cfgfile} IN @{cfgfiles}
113 \ SSHLibrary.Execute_Command sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}
114 \ SSHLibrary.Execute_Command sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}
115 \ SSHLibrary.Execute_Command sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}
116 \ SSHLibrary.Execute_Command sed -i -e 's/ADDPATH/disable/g' ${cfgfile}
117 \ ${stdout}= SSHLibrary.Execute_Command cat ${cfgfile}
121 [Arguments] ${cfg_file} ${url} ${empty_response}
122 [Documentation] Verifies initial test condition and starts the tool
123 Verify_Reported_Data ${url} ${empty_response}
124 Start_Tool_And_Verify_Connected ${cfg_file}
127 [Arguments] ${cfg_file} ${mapping}={}
128 [Documentation] Start the tool ${cmd} ${cfg_file}
129 ${start_cmd} BuiltIn.Set_Variable ${cmd} ${cfg_file}
130 BuiltIn.Log ${start_cmd}
131 SSHKeywords.Virtual_Env_Activate_On_Current_Session log_output=${True}
132 ${output}= SSHLibrary.Write ${start_cmd}
133 BuiltIn.Log ${output}
135 Verify_Tools_Connection
136 [Arguments] ${connected}=${True}
137 [Documentation] Checks peer presence in operational datastore
138 ${exp_status_code}= BuiltIn.Set_Variable_If ${connected} ${200} ${404}
139 ${rsp}= RequestsLibrary.Get Request ${CONFIG_SESSION} ${PEER_CHECK_URL}${TOOLS_SYSTEM_IP}
140 BuiltIn.Log ${rsp.content}
141 BuiltIn.Should_Be_Equal_As_Numbers ${exp_status_code} ${rsp.status_code}
143 Start_Tool_And_Verify_Connected
144 [Arguments] ${cfg_file}
145 [Documentation] Start the tool and verify its connection
146 KarafKeywords.Log_Testcase_Start_To_Controller_Karaf
147 Start_Tool ${cfg_file}
148 BuiltIn.Wait_Until_Keyword_Succeeds 3x 3s Verify_Tools_Connection connected=${True}
151 [Documentation] Stop the tool by sending ctrl+c
152 ${output}= SSHLibrary.Read
153 BuiltIn.Log ${output}
154 Utils.Write_Bare_Ctrl_C
155 ${output}= SSHLibrary.Read_Until_Prompt
156 BuiltIn.Log ${output}
157 SSHKeywords.Virtual_Env_Deactivate_On_Current_Session log_output=${True}
159 Remove_Route_And_Stop_Tool
160 [Documentation] Removes configured route from application peer and stops the tool
161 &{mapping} BuiltIn.Create_Dictionary
162 TemplatedRequests.Delete_Templated ${BGP_L3VPN_DIR}/route mapping=${mapping} session=${CONFIG_SESSION}
166 [Arguments] ${url} ${empty_response}
167 [Documentation] Testcse teardown with data verification
169 BuiltIn.Wait_Until_Keyword_Succeeds 3x 1s Verify_Reported_Data ${url} ${empty_response}
171 Verify_Tool_Received_Update
172 [Arguments] ${exp_update_fn}
173 [Documentation] Verification of receiving particular update message
174 ${exp_update}= Get_Expected_Response_From_File ${exp_update_fn}
175 ${rcv_update_dict}= BgpRpcClient.exa_get_update_message msg_only=${True}
176 ${rcv_update}= BuiltIn.Evaluate json.dumps(${rcv_update_dict}) modules=json
177 ${received_json}= norm_json.Normalize_Json_Text ${rcv_update}
178 ${expected_json}= norm_json.Normalize_Json_Text ${exp_update}
179 BuiltIn.Log ${received_json}
180 BuiltIn.Log ${expected_json}
181 BuiltIn.Should_Be_Equal ${received_json} ${expected_json}
184 [Arguments] ${url} ${exprspfile}
185 [Documentation] Verifies expected response
186 ${expected_rsp}= Get_Expected_Response_From_File ${exprspfile}
187 ${expected_json}= norm_json.Normalize_Json_Text ${expected_rsp}
188 ${rsp}= RequestsLibrary.Get_Request ${CONFIG_SESSION} ${url}
189 BuiltIn.Log ${rsp.content}
190 ${received_json}= norm_json.Normalize_Json_Text ${rsp.content}
191 BuiltIn.Log ${received_json}
192 BuiltIn.Log ${expected_json}
193 BuiltIn.Should_Be_Equal ${received_json} ${expected_json}
195 Get_Expected_Response_From_File
196 [Arguments] ${exprspfile}
197 [Documentation] Looks for release specific response first, then take default.
198 ${status} ${expresponse}= BuiltIn.Run_Keyword_And_Ignore_Error OperatingSystem.Get File ${exprspfile}.${ODL_STREAM}
199 Return From Keyword If '${status}' == 'PASS' ${expresponse}
200 ${expresponse}= OperatingSystem.Get File ${exprspfile}
201 [Return] ${expresponse}