Fix robot syntax
[integration/test.git] / csit / suites / bgpcep / bgpuser / ibgp_peers_basic.robot
1 *** Settings ***
2 Documentation     Basic tests for iBGP peers.
3 ...
4 ...               Copyright (c) 2015-2018 Cisco Systems, Inc. and others. All rights reserved.
5 ...
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
9 ...
10 ...               Test suite performs basic iBGP functional test cases for
11 ...               BGP peers in different roles (iBGP, iBGP RR-client):
12 ...
13 ...               Test Case 1: Two iBGP RR-client peers introduce prefixes
14 ...               Expected result: controller forwards updates towards both peers
15 ...
16 ...               Test Case 2: Two iBGP peers: one RR client and one non-client introduces prefixes
17 ...               Expected result: controller forwards updates towards both peers
18 ...
19 ...               Test Case 3: Two iBGP RR non-client peers introduce prefixes
20 ...               Expected result: controller does not forward any update towards peers
21 ...
22 ...               Test Case 4: Two iBGP(play.py) RR-client peers configured, first of them configured
23 ...               with route-reflector-cluster-id, second inherits it's cluster-id from global config.
24 ...               Each of them introduces 3 prefixes.
25 ...               Expected result: controller forwards updates towards both peers and each of their
26 ...               adj-rib-in contains routes. First peer should contain default cluster-id and
27 ...               second cluster-id from first peers configuration.
28 ...
29 ...               For polices see: https://wiki.opendaylight.org/view/BGP_LS_PCEP:BGP
30 Suite Setup       Setup_Everything
31 Suite Teardown    BgpOperations.Teardown_Everything
32 Test Setup        SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
33 Test Teardown     FailFast.Start_Failing_Fast_If_This_Failed
34 Library           OperatingSystem
35 Library           RequestsLibrary
36 Library           DateTime
37 Variables         ../../../variables/bgpuser/variables.py    ${TOOLS_SYSTEM_IP}    ${ODL_STREAM}
38 Resource          ../../../variables/Variables.robot
39 Resource          ../../../libraries/BGPcliKeywords.robot
40 Resource          ../../../libraries/BgpOperations.robot
41 Resource          ../../../libraries/FailFast.robot
42 Resource          ../../../libraries/SetupUtils.robot
43 Resource          ../../../libraries/SSHKeywords.robot
44 Resource          ../../../libraries/TemplatedRequests.robot
45 Resource          ../../../libraries/CompareStream.robot
46
47 *** Variables ***
48 ${BGP_VARIABLES_FOLDER}    ${CURDIR}/../../../variables/bgpuser/
49 ${HOLDTIME}       180
50 ${BGP_PEER_LOG_LEVEL}    debug
51 ${ODL_LOG_LEVEL}    INFO
52 ${ODL_BGP_LOG_LEVEL}    DEFAULT
53 ${DEVICE_NAME}    controller-config
54 ${BGP_PEER1_IP}    127.0.0.1
55 ${BGP_PEER2_IP}    127.0.0.2
56 ${BGP_PEER1_FIRST_PREFIX_IP}    8.1.0.0
57 ${BGP_PEER2_FIRST_PREFIX_IP}    8.2.0.0
58 ${PREFIX_LEN}     28
59 ${BGP_PEER1_PREFIX_LEN}    ${PREFIX_LEN}
60 ${BGP_PEER2_PREFIX_LEN}    ${PREFIX_LEN}
61 ${PREFIX_COUNT}    3
62 ${BGP_PEER1_PREFIX_COUNT}    ${PREFIX_COUNT}
63 ${BGP_PEER2_PREFIX_COUNT}    ${PREFIX_COUNT}
64 ${BGP_PEER1_LOG_FILE}    bgp_peer1.log
65 ${BGP_PEER2_LOG_FILE}    bgp_peer2.log
66 ${BGP_PEER1_COMMAND}    python play.py --firstprefix ${BGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${BGP_PEER1_PREFIX_LEN} --amount ${BGP_PEER1_PREFIX_COUNT} --myip=${BGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --${BGP_PEER_LOG_LEVEL} --logfile ${BGP_PEER1_LOG_FILE}
67 ${BGP_PEER2_COMMAND}    python play.py --firstprefix ${BGP_PEER2_FIRST_PREFIX_IP} --prefixlen ${BGP_PEER2_PREFIX_LEN} --amount ${BGP_PEER2_PREFIX_COUNT} --myip=${BGP_PEER2_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --${BGP_PEER_LOG_LEVEL} --logfile ${BGP_PEER2_LOG_FILE}
68 ${BGP_PEER1_OPTIONS}    &>${BGP_PEER1_LOG_FILE}
69 ${BGP_PEER2_OPTIONS}    &>${BGP_PEER2_LOG_FILE}
70 ${DEFAULT_LOG_CHECK_TIMEOUT}    20s
71 ${DEFAULT_LOG_CHECK_PERIOD}    1s
72 ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    10s
73 ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    1s
74 ${CONFIG_SESSION}    session
75 ${RIB_INSTANCE}    example-bgp-rib
76 ${PROTOCOL_OPENCONFIG}    ${RIB_INSTANCE}
77
78 *** Test Cases ***
79 TC1_Configure_Two_iBGP_Route_Reflector_Client_Peers
80     [Documentation]    Configure two iBGP peers as routing reflector clients.
81     [Tags]    critical
82     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer1    IP=${BGP_PEER1_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}
83     ...    PEER_ROLE=rr-client    INITIATE=false    BGP_RIB=${RIB_INSTANCE}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    RIB_INSTANCE_NAME=${RIB_INSTANCE}
84     ...    RR_CLIENT=true
85     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
86     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer2    IP=${BGP_PEER2_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}
87     ...    PEER_ROLE=rr-client    INITIATE=false    BGP_RIB=${RIB_INSTANCE}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    RIB_INSTANCE_NAME=${RIB_INSTANCE}
88     ...    RR_CLIENT=true
89     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
90
91 TC1_Connect_BGP_Peer1
92     [Documentation]    Connect BGP peer
93     [Tags]    critical
94     SSHLibrary.Switch Connection    bgp_peer1_console
95     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER1_COMMAND}    ${BGP_PEER1_OPTIONS}
96     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
97
98 TC1_Connect_BGP_Peer2
99     [Documentation]    Connect BGP peer
100     [Tags]    critical
101     SSHLibrary.Switch Connection    bgp_peer2_console
102     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER2_COMMAND}    ${BGP_PEER2_OPTIONS}
103     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
104
105 TC1_BGP_Peer1_Check_Log_For_Introduced_Prefixes
106     [Documentation]    Check incomming updates for new routes
107     [Tags]    critical
108     SSHLibrary.Switch Connection    bgp_peer1_console
109     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_LOG_CHECK_TIMEOUT}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER1_LOG_FILE}    nlri_prefix_received:    ${BGP_PEER2_PREFIX_COUNT}
110     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER1_LOG_FILE}    nlri_prefix_received: ${BGP_PEER2_FIRST_PREFIX_IP}/${BGP_PEER2_PREFIX_LEN}    1
111     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER1_LOG_FILE}    withdrawn_prefix_received:    0
112
113 TC1_BGP_Peer2_Check_Log_For_Introduced_Prefixes
114     [Documentation]    Check incomming updates for new routes
115     [Tags]    critical
116     SSHLibrary.Switch Connection    bgp_peer2_console
117     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_LOG_CHECK_TIMEOUT}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    nlri_prefix_received:    ${BGP_PEER1_PREFIX_COUNT}
118     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    nlri_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}    1
119     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    withdrawn_prefix_received:    0
120
121 TC1_Disconnect_BGP_Peer1
122     [Documentation]    Stop BGP peer & store logs
123     [Tags]    critical
124     SSHLibrary.Switch Connection    bgp_peer1_console
125     BGPCliKeywords.Stop_Console_Tool
126     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER1_LOG_FILE}    tc1_${BGP_PEER1_LOG_FILE}
127
128 TC1_BGP_Peer2_Check_Log_For_Withdrawn_Prefixes
129     [Documentation]    Check incomming updates for withdrawn routes
130     [Tags]    critical
131     SSHLibrary.Switch Connection    bgp_peer2_console
132     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_LOG_CHECK_TIMEOUT}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    withdrawn_prefix_received:    ${BGP_PEER1_PREFIX_COUNT}
133     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    withdrawn_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}    1
134
135 TC1_Disconnect_BGP_Peer2
136     [Documentation]    Stop BGP peer & store logs
137     [Tags]    critical
138     SSHLibrary.Switch Connection    bgp_peer2_console
139     BGPCliKeywords.Stop_Console_Tool
140     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER2_LOG_FILE}    tc1_${BGP_PEER2_LOG_FILE}
141
142 TC_1_Check_for_Empty_IPv4_Topology
143     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain    prefix
144
145 TC1_Delete_BGP_Peers_Configuration
146     [Documentation]    Delete all previously configured BGP peers.
147     [Tags]    critical
148     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer1    IP=${BGP_PEER1_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
149     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
150     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer2    IP=${BGP_PEER2_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
151     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
152
153 TC2_Configure_One_iBGP_Route_Reflector_Client_And_One_iBGP_Non_Client
154     [Documentation]    Configure iBGP peers: 1st one as RR client, 2nd one as RR non-client.
155     [Tags]    critical
156     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer1    IP=${BGP_PEER1_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}
157     ...    PEER_ROLE=rr-client    INITIATE=false    BGP_RIB=${RIB_INSTANCE}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    RIB_INSTANCE_NAME=${RIB_INSTANCE}
158     ...    RR_CLIENT=true
159     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
160     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer2    IP=${BGP_PEER2_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}
161     ...    PEER_ROLE=ibgp    INITIATE=false    BGP_RIB=${RIB_INSTANCE}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    RIB_INSTANCE_NAME=${RIB_INSTANCE}
162     ...    RR_CLIENT=false
163     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
164
165 TC2_Connect_BGP_Peer1
166     [Documentation]    Connect BGP peer
167     [Tags]    critical
168     SSHLibrary.Switch Connection    bgp_peer1_console
169     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER1_COMMAND}    ${BGP_PEER1_OPTIONS}
170     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
171
172 TC2_Connect_BGP_Peer2
173     [Documentation]    Connect BGP peer
174     [Tags]    critical
175     SSHLibrary.Switch Connection    bgp_peer2_console
176     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER2_COMMAND}    ${BGP_PEER2_OPTIONS}
177     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
178
179 TC2_BGP_Peer1_Check_Log_For_Introduced_Prefixes
180     [Documentation]    Check incomming updates for new routes
181     [Tags]    critical
182     SSHLibrary.Switch Connection    bgp_peer1_console
183     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_LOG_CHECK_TIMEOUT}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER1_LOG_FILE}    nlri_prefix_received:    ${BGP_PEER2_PREFIX_COUNT}
184     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER1_LOG_FILE}    nlri_prefix_received: ${BGP_PEER2_FIRST_PREFIX_IP}/${BGP_PEER2_PREFIX_LEN}    1
185     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER1_LOG_FILE}    withdrawn_prefix_received:    0
186
187 TC2_BGP_Peer2_Check_Log_For_Introduced_Prefixes
188     [Documentation]    Check incomming updates for new routes
189     [Tags]    critical
190     SSHLibrary.Switch Connection    bgp_peer2_console
191     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_LOG_CHECK_TIMEOUT}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    nlri_prefix_received:    ${BGP_PEER1_PREFIX_COUNT}
192     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    nlri_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}    1
193     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    withdrawn_prefix_received:    0
194
195 TC2_Disconnect_BGP_Peer1
196     [Documentation]    Stop BGP peer & store logs
197     [Tags]    critical
198     SSHLibrary.Switch Connection    bgp_peer1_console
199     BGPCliKeywords.Stop_Console_Tool
200     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER1_LOG_FILE}    tc2_${BGP_PEER1_LOG_FILE}
201
202 TC2_BGP_Peer2_Check_Log_For_Withdrawn_Prefixes
203     [Documentation]    Check incomming updates for withdrawn routes
204     [Tags]    critical
205     SSHLibrary.Switch Connection    bgp_peer2_console
206     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_LOG_CHECK_TIMEOUT}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    withdrawn_prefix_received:    ${BGP_PEER1_PREFIX_COUNT}
207     BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    withdrawn_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}    1
208
209 TC2_Disconnect_BGP_Peer2
210     [Documentation]    Stop BGP peer & store logs
211     [Tags]    critical
212     SSHLibrary.Switch Connection    bgp_peer2_console
213     BGPCliKeywords.Stop_Console_Tool
214     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER2_LOG_FILE}    tc2_${BGP_PEER2_LOG_FILE}
215
216 TC_2_Check_for_Empty_IPv4_Topology
217     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain    prefix
218
219 TC2_Delete_BGP_Peers_Configuration
220     [Documentation]    Delete all previously configured BGP peers.
221     [Tags]    critical
222     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer1    IP=${BGP_PEER1_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
223     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
224     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer2    IP=${BGP_PEER2_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
225     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
226
227 TC3_Configure_Two_iBGP_Non_Client_Peers
228     [Documentation]    Configure iBGP peers: 1st one as RR client, 2nd one as RR non-client.
229     [Tags]    critical
230     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer1    IP=${BGP_PEER1_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}
231     ...    PEER_ROLE=ibgp    INITIATE=false    BGP_RIB=${RIB_INSTANCE}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    RIB_INSTANCE_NAME=${RIB_INSTANCE}
232     ...    RR_CLIENT=false
233     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
234     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer2    IP=${BGP_PEER2_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}
235     ...    PEER_ROLE=ibgp    INITIATE=false    BGP_RIB=${RIB_INSTANCE}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    RIB_INSTANCE_NAME=${RIB_INSTANCE}
236     ...    RR_CLIENT=false
237     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
238
239 TC3_Connect_BGP_Peer1
240     [Documentation]    Connect BGP peer
241     [Tags]    critical
242     SSHLibrary.Switch Connection    bgp_peer1_console
243     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER1_COMMAND}    ${BGP_PEER1_OPTIONS}
244     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
245
246 TC3_Connect_BGP_Peer2
247     [Documentation]    Connect BGP peer
248     [Tags]    critical
249     SSHLibrary.Switch Connection    bgp_peer2_console
250     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER2_COMMAND}    ${BGP_PEER2_OPTIONS}
251     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
252
253 TC3_BGP_Peer1_Check_Log_For_No_Updates
254     [Documentation]    Check for no updates received by iBGP peer No. 1
255     [Tags]    critical
256     SSHLibrary.Switch Connection    bgp_peer1_console
257     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_LOG_CHECK_TIMEOUT}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER1_LOG_FILE}    total_received_update_message_counter: 0    2
258
259 TC3_Disconnect_BGP_Peer1
260     [Documentation]    Stop BGP peer & store logs
261     [Tags]    critical
262     SSHLibrary.Switch Connection    bgp_peer1_console
263     BGPCliKeywords.Stop_Console_Tool
264     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER1_LOG_FILE}    tc3_${BGP_PEER1_LOG_FILE}
265
266 TC3_BGP_Peer2_Check_Log_For_No_Updates
267     [Documentation]    Consequent check for no updates received by iBGP peer No. 2
268     [Tags]    critical
269     SSHLibrary.Switch Connection    bgp_peer2_console
270     ${log_check_timeout}=    DateTime.Convert_Time    ${DEFAULT_LOG_CHECK_TIMEOUT}    result_format=number
271     BuiltIn.Wait_Until_Keyword_Succeeds    ${log_check_timeout*2}    ${DEFAULT_LOG_CHECK_PERIOD}    BGPCliKeywords.Check_File_For_Word_Count    ${BGP_PEER2_LOG_FILE}    total_received_update_message_counter: 0    4
272
273 TC3_Disconnect_BGP_Peer2
274     [Documentation]    Stop BGP peer & store logs
275     [Tags]    critical
276     SSHLibrary.Switch Connection    bgp_peer2_console
277     BGPCliKeywords.Stop_Console_Tool
278     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER2_LOG_FILE}    tc3_${BGP_PEER2_LOG_FILE}
279
280 TC_3_Check_for_Empty_IPv4_Topology
281     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain    prefix
282
283 TC3_Delete_BGP_Peers_Configuration
284     [Documentation]    Delete all previously configured BGP peers.
285     [Tags]    critical
286     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer1    IP=${BGP_PEER1_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
287     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
288     &{mapping}    BuiltIn.Create_Dictionary    DEVICE_NAME=${DEVICE_NAME}    NAME=example-bgp-peer2    IP=${BGP_PEER2_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
289     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
290
291 TC4_Configure_Two_iBGP_RR_Clients_With_Cluster_Id
292     [Documentation]    Configure two iBGP peers as routing reflector clients with cluster-id argument.
293     [Tags]    critical
294     CompareStream.Run_Keyword_If_Less_Than_Fluorine    BuiltIn.Pass_Execution    Test case valid for version fluorine and above.
295     &{mapping}    BuiltIn.Create_Dictionary    IP=${BGP_PEER1_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
296     ...    RR_CLIENT=true
297     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}cluster_id/ibgp_peer    mapping=${mapping}    session=${CONFIG_SESSION}
298     &{mapping}    BuiltIn.Create_Dictionary    IP=${BGP_PEER2_IP}    HOLDTIME=${HOLDTIME}    PEER_PORT=${BGP_TOOL_PORT}    PASSIVE_MODE=true    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
299     ...    RR_CLIENT=true
300     TemplatedRequests.Put_As_Xml_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
301
302 TC4_Connect_BGP_Peers
303     [Documentation]    Connect BGP peers, each set to send 3 prefixes.
304     [Tags]    critical
305     CompareStream.Run_Keyword_If_Less_Than_Fluorine    BuiltIn.Pass_Execution    Test case valid for version fluorine and above.
306     SSHLibrary.Switch Connection    bgp_peer1_console
307     BuiltIn.Set_Suite_Variable    ${peer1_cluster_id}    127.0.0.4
308     BuiltIn.Set_Suite_Variable    ${default_cluster_id}    192.0.2.2
309     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER1_COMMAND} --cluster=${peer1_cluster_id}    ${BGP_PEER1_OPTIONS}
310     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
311     SSHLibrary.Switch Connection    bgp_peer2_console
312     BGPCliKeywords.Start_Console_Tool    ${BGP_PEER2_COMMAND} --cluster=${BGP_PEER2_IP}    ${BGP_PEER2_OPTIONS}
313     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Content    {"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}
314
315 TC4_BGP_Peer1_Check_Rib_Out_For_Introduced_Prefixes
316     [Documentation]    Check incomming updates for new routes and respective cluster-ids
317     ...    on first peer which should contain default-cluster id from global config reflected
318     ...    from the second peer equal to router-id.
319     [Tags]    critical
320     CompareStream.Run_Keyword_If_Less_Than_Fluorine    BuiltIn.Pass_Execution    Test case valid for version fluorine and above.
321     &{mapping}    BuiltIn.Create_Dictionary    IP=${BGP_PEER1_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    PEER_NUMBER=2    CLUSTER_ID=${BGP_PEER2_IP}    DEFAULT_ID=${default_cluster_id}
322     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    TemplatedRequests.Get_As_Json_Templated    ${BGP_VARIABLES_FOLDER}${/}cluster_id/peer_rib_out    mapping=${mapping}    session=${CONFIG_SESSION}
323     ...    verify=True
324
325 TC4_BGP_Peer2_Check_Rib_Out_For_Introduced_Prefixes
326     [Documentation]    Check incomming updates for new routes and respective cluster-ids
327     ...    in second peer which has local route-reflector-cluster-id
328     [Tags]    critical
329     CompareStream.Run_Keyword_If_Less_Than_Fluorine    BuiltIn.Pass_Execution    Test case valid for version fluorine and above.
330     &{mapping}    BuiltIn.Create_Dictionary    IP=${BGP_PEER2_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}    PEER_NUMBER=1    CLUSTER_ID=${BGP_PEER1_IP}    DEFAULT_ID=${peer1_cluster_id}
331     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    TemplatedRequests.Get_As_Json_Templated    ${BGP_VARIABLES_FOLDER}${/}cluster_id/peer_rib_out    mapping=${mapping}    session=${CONFIG_SESSION}
332     ...    verify=True
333
334 TC4_Disconnect_BGP_Peers
335     [Documentation]    Stop BGP peer & store logs
336     [Tags]    critical
337     CompareStream.Run_Keyword_If_Less_Than_Fluorine    BuiltIn.Pass_Execution    Test case valid for version fluorine and above.
338     SSHLibrary.Switch Connection    bgp_peer1_console
339     BGPCliKeywords.Stop_Console_Tool
340     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER1_LOG_FILE}    tc4_${BGP_PEER1_LOG_FILE}
341     SSHLibrary.Switch Connection    bgp_peer2_console
342     BGPCliKeywords.Stop_Console_Tool
343     BGPCliKeywords.Store_File_To_Workspace    ${BGP_PEER2_LOG_FILE}    tc4_${BGP_PEER2_LOG_FILE}
344
345 TC4_Check_for_Empty_IPv4_Topology
346     [Documentation]    Checks for empty topology after
347     CompareStream.Run_Keyword_If_Less_Than_Fluorine    BuiltIn.Pass_Execution    Test case valid for version fluorine and above.
348     BuiltIn.Wait_Until_Keyword_Succeeds    ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}    ${DEFAULT_TOPOLOGY_CHECK_PERIOD}    BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain    prefix
349
350 TC4_Delete_BGP_Peers_Configuration
351     [Documentation]    Delete all previously configured BGP peers.
352     [Tags]    critical
353     CompareStream.Run_Keyword_If_Less_Than_Fluorine    BuiltIn.Pass_Execution    Test case valid for version fluorine and above.
354     &{mapping}    BuiltIn.Create_Dictionary    IP=${BGP_PEER1_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
355     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}cluster_id/ibgp_peer    mapping=${mapping}    session=${CONFIG_SESSION}
356     &{mapping}    BuiltIn.Create_Dictionary    IP=${BGP_PEER2_IP}    BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
357     TemplatedRequests.Delete_Templated    ${BGP_VARIABLES_FOLDER}${/}ibgp_peers    mapping=${mapping}    session=${CONFIG_SESSION}
358
359 *** Keywords ***
360 Setup_Everything
361     [Documentation]    Initialize SetupUtils. SSH-login to mininet machine, create HTTP session,
362     ...    prepare directories for responses, put Python tool to mininet machine, setup imported resources.
363     # TODO: Choose keywords used by more than one test suite to be placed in a common place.
364     SetupUtils.Setup_Utils_For_Setup_And_Teardown
365     SSHLibrary.Set_Default_Configuration    prompt=${ODL_SYSTEM_PROMPT}
366     SSHLibrary.Open_Connection    ${ODL_SYSTEM_IP}    alias=bgp_peer1_console
367     SSHKeywords.Flexible_Controller_Login
368     SSHLibrary.Open_Connection    ${ODL_SYSTEM_IP}    alias=bgp_peer2_console
369     SSHKeywords.Flexible_Controller_Login
370     SSHKeywords.Require_Python
371     SSHKeywords.Assure_Library_Ipaddr    target_dir=.
372     SSHLibrary.Put_File    ${CURDIR}/../../../../tools/fastbgp/play.py
373     RequestsLibrary.Create_Session    operational    http://${ODL_SYSTEM_IP}:${RESTCONFPORT}${OPERATIONAL_TOPO_API}    auth=${AUTH}
374     RequestsLibrary.Create_Session    ${CONFIG_SESSION}    http://${ODL_SYSTEM_IP}:${RESTCONFPORT}    auth=${AUTH}
375     KarafKeywords.Execute_Controller_Karaf_Command_On_Background    log:set ${ODL_LOG_LEVEL}
376     KarafKeywords.Execute_Controller_Karaf_Command_On_Background    log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.bgpcep
377     KarafKeywords.Execute_Controller_Karaf_Command_On_Background    log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.protocol