2 Documentation BGP performance of ingesting from 1 iBGP peer, data change counter is NOT used.
4 ... Copyright (c) 2015-2017 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 uses play.py as single iBGP peer which talks to
11 ... single controller in three node cluster configuration.
12 ... Test suite checks changes of the the example-ipv4-topology on all nodes.
13 ... RIB is not examined.
15 ... singlepeer_pc_shm_300kroutes_shards_local:
16 ... pc - prefix counting
17 ... shm - shard monitoring (during the process of prefix advertizing)
18 ... shards_local - default and topology shards are on the same node as rib owner
19 ... singleton instance
20 Suite Setup PrefixcountKeywords.Setup_Everything
21 Suite Teardown PrefixcountKeywords.Teardown_Everything
22 Test Setup SetupUtils.Setup_Test_With_Logging_And_Fast_Failing
23 Test Teardown SetupUtils.Teardown_Test_Show_Bugs_And_Start_Fast_Failing_If_Test_Failed
24 Library SSHLibrary timeout=10s
25 Library RequestsLibrary
26 Resource ${CURDIR}/../../../variables/Variables.robot
27 Resource ${CURDIR}/../../../libraries/BGPSpeaker.robot
28 Resource ${CURDIR}/../../../libraries/BGPcliKeywords.robot
29 Resource ${CURDIR}/../../../libraries/FailFast.robot
30 Resource ${CURDIR}/../../../libraries/KillPythonTool.robot
31 Resource ${CURDIR}/../../../libraries/PrefixCounting.robot
32 Resource ${CURDIR}/../../../libraries/SetupUtils.robot
33 Resource ${CURDIR}/../../../libraries/ClusterManagement.robot
34 Resource ${CURDIR}/../../../libraries/SSHKeywords.robot
35 Resource ${CURDIR}/../../../libraries/TemplatedRequests.robot
36 Resource ${CURDIR}/../../../libraries/CompareStream.robot
37 Resource ${CURDIR}/PrefixcountKeywords.robot
43 Get_Example_Bgp_Rib_Owner
44 [Documentation] Find an odl node which is able to accept incomming connection. It is a node, which is the owner of bgp rib, as it is a singleton service.
45 ... This node should be used for bgp peer to connect to.
46 ${rib_owner} ${rib_candidates}= ClusterManagement.Get_Owner_And_Successors_For_device example-bgp-rib org.opendaylight.mdsal.ServiceEntityType 1
47 BuiltIn.Set_Suite_Variable ${rib_owner} ${rib_owner}
48 BuiltIn.Set_Suite_Variable ${rib_candidates} ${rib_candidates}
49 BuiltIn.Set_Suite_Variable ${rib_owner_node_id} ${ODL_SYSTEM_${rib_owner}_IP}
50 RequestsLibrary.Create_Session ${CONFIG_SESSION} http://${ODL_SYSTEM_${rib_owner}_IP}:${RESTCONFPORT} auth=${AUTH} timeout=10 max_retries=0
52 Move_Shard_Leaders_If_Needed
53 [Documentation] Set shard leaders to expected location
54 PrefixcountKeywords.Set_Shard_Leaders_Location_And_Verify ${rib_owner}
56 Check_For_Empty_Ipv4_Topology_Before_Talking_1
57 [Documentation] Wait for ${EXAMPLE_IPV4_TOPOLOGY} to come up and empty. Give large timeout for case when BGP boots slower than restconf.
59 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
60 BuiltIn.Wait_Until_Keyword_Succeeds ${INITIAL_RESTCONF_TIMEOUT} 1s PrefixCounting.Check_Ipv4_Topology_Is_Empty session=${CONFIGURATION_1} topology=${EXAMPLE_IPV4_TOPOLOGY}
62 Check_For_Empty_Ipv4_Topology_Before_Talking_2
63 [Documentation] Wait for ${EXAMPLE_IPV4_TOPOLOGY} to come up and empty. Give large timeout for case when BGP boots slower than restconf.
65 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
66 BuiltIn.Wait_Until_Keyword_Succeeds ${INITIAL_RESTCONF_TIMEOUT} 1s PrefixCounting.Check_Ipv4_Topology_Is_Empty session=${CONFIGURATION_2} topology=${EXAMPLE_IPV4_TOPOLOGY}
68 Check_For_Empty_Ipv4_Topology_Before_Talking_3
69 [Documentation] Wait for ${EXAMPLE_IPV4_TOPOLOGY} to come up and empty. Give large timeout for case when BGP boots slower than restconf.
71 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
72 BuiltIn.Wait_Until_Keyword_Succeeds ${INITIAL_RESTCONF_TIMEOUT} 1s PrefixCounting.Check_Ipv4_Topology_Is_Empty session=${CONFIGURATION_3} topology=${EXAMPLE_IPV4_TOPOLOGY}
74 Reconfigure_ODL_To_Accept_Connection
75 [Documentation] Configure BGP peer module with initiate-connection set to false.
76 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
77 &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} BGP_NAME=${BGP_PEER_NAME} IP=${TOOLS_SYSTEM_IP} HOLDTIME=${HOLDTIME} PEER_PORT=${BGP_TOOL_PORT}
78 ... INITIATE=false BGP_RIB=${RIB_INSTANCE} PASSIVE_MODE=true BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
79 TemplatedRequests.Put_As_Json_Templated ${BGP_VARIABLES_FOLDER} mapping=${mapping} session=${CONFIG_SESSION}
80 [Teardown] SetupUtils.Teardown_Test_Show_Bugs_If_Test_Failed
82 Start_Talking_BGP_Speaker
83 [Documentation] Start Python speaker to connect to ODL.
84 PrefixcountKeywords.Start_Bgp_Peer_And_Verify_Connected connection_retries=${3}
86 Wait_For_Stable_Talking_Ipv4_Topology_1
87 [Documentation] Wait until ${EXAMPLE_IPV4_TOPOLOGY} becomes stable. This is done by checking stability of prefix count as seen from node 1.
88 PrefixCounting.Wait_For_Ipv4_Topology_Prefixes_To_Become_Stable timeout=${bgp_filling_timeout} period=${CHECK_PERIOD} repetitions=${REPETITIONS} excluded_count=0 session=${CONFIGURATION_1} topology=${EXAMPLE_IPV4_TOPOLOGY}
89 ... shards_list=${SHARD_MONITOR_LIST} shards_details=${init_shard_details}
91 Wait_For_Stable_Talking_Ipv4_Topology_2
92 [Documentation] Wait until ${EXAMPLE_IPV4_TOPOLOGY} becomes stable. This is done by checking stability of prefix count as seen from node 2.
93 PrefixCounting.Wait_For_Ipv4_Topology_Prefixes_To_Become_Stable timeout=${bgp_filling_timeout} period=${CHECK_PERIOD} repetitions=${REPETITIONS} excluded_count=0 session=${CONFIGURATION_2} topology=${EXAMPLE_IPV4_TOPOLOGY}
95 Wait_For_Stable_Talking_Ipv4_Topology_3
96 [Documentation] Wait until ${EXAMPLE_IPV4_TOPOLOGY} becomes stable. This is done by checking stability of prefix count as seen from node 3.
97 PrefixCounting.Wait_For_Ipv4_Topology_Prefixes_To_Become_Stable timeout=${bgp_filling_timeout} period=${CHECK_PERIOD} repetitions=${REPETITIONS} excluded_count=0 session=${CONFIGURATION_3} topology=${EXAMPLE_IPV4_TOPOLOGY}
99 Check_Talking_Ipv4_Topology_Count_1
100 [Documentation] Count the routes in ${EXAMPLE_IPV4_TOPOLOGY} and fail if the count is not correct as seen from node 1.
102 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
103 PrefixCounting.Check_Ipv4_Topology_Count ${COUNT} session=${CONFIGURATION_1} topology=${EXAMPLE_IPV4_TOPOLOGY}
105 Check_Talking_Ipv4_Topology_Count_2
106 [Documentation] Count the routes in ${EXAMPLE_IPV4_TOPOLOGY} and fail if the count is not correct as seen from node 2.
108 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
109 PrefixCounting.Check_Ipv4_Topology_Count ${COUNT} session=${CONFIGURATION_2} topology=${EXAMPLE_IPV4_TOPOLOGY}
111 Check_Talking_Ipv4_Topology_Count_3
112 [Documentation] Count the routes in ${EXAMPLE_IPV4_TOPOLOGY} and fail if the count is not correct as seen from node 3.
114 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
115 PrefixCounting.Check_Ipv4_Topology_Count ${COUNT} session=${CONFIGURATION_3} topology=${EXAMPLE_IPV4_TOPOLOGY}
117 Kill_Talking_BGP_Speaker
118 [Documentation] Abort the Python speaker. Also, attempt to stop failing fast.
120 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
121 BGPSpeaker.Kill_BGP_Speaker
122 FailFast.Do_Not_Fail_Fast_From_Now_On
124 Wait_For_Stable_Ipv4_Topology_After_Listening_1
125 [Documentation] Wait until ${EXAMPLE_IPV4_TOPOLOGY} becomes stable again as seen from node 1.
127 PrefixCounting.Wait_For_Ipv4_Topology_Prefixes_To_Become_Stable timeout=${bgp_filling_timeout} period=${CHECK_PERIOD} repetitions=${REPETITIONS} excluded_count=${COUNT} session=${CONFIGURATION_1} topology=${EXAMPLE_IPV4_TOPOLOGY}
129 Wait_For_Stable_Ipv4_Topology_After_Listening_2
130 [Documentation] Wait until ${EXAMPLE_IPV4_TOPOLOGY} becomes stable again as seen from node 2.
132 PrefixCounting.Wait_For_Ipv4_Topology_Prefixes_To_Become_Stable timeout=${bgp_filling_timeout} period=${CHECK_PERIOD} repetitions=${REPETITIONS} excluded_count=${COUNT} session=${CONFIGURATION_2} topology=${EXAMPLE_IPV4_TOPOLOGY}
134 Wait_For_Stable_Ipv4_Topology_After_Listening_3
135 [Documentation] Wait until ${EXAMPLE_IPV4_TOPOLOGY} becomes stable again as seen from node 3.
137 PrefixCounting.Wait_For_Ipv4_Topology_Prefixes_To_Become_Stable timeout=${bgp_filling_timeout} period=${CHECK_PERIOD} repetitions=${REPETITIONS} excluded_count=${COUNT} session=${CONFIGURATION_3} topology=${EXAMPLE_IPV4_TOPOLOGY}
139 Check_For_Empty_Ipv4_Topology_After_Listening_1
140 [Documentation] Example-ipv4-topology should be empty now as seen from node 1.
142 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
143 PrefixCounting.Check_Ipv4_Topology_Is_Empty session=${CONFIGURATION_1} topology=${EXAMPLE_IPV4_TOPOLOGY}
145 Check_For_Empty_Ipv4_Topology_After_Listening_2
146 [Documentation] Example-ipv4-topology should be empty now as seen from node 2.
148 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
149 PrefixCounting.Check_Ipv4_Topology_Is_Empty session=${CONFIGURATION_2} topology=${EXAMPLE_IPV4_TOPOLOGY}
151 Check_For_Empty_Ipv4_Topology_After_Listening_3
152 [Documentation] Example-ipv4-topology should be empty now as seen from node 3.
154 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
155 PrefixCounting.Check_Ipv4_Topology_Is_Empty session=${CONFIGURATION_3} topology=${EXAMPLE_IPV4_TOPOLOGY}
157 Delete_Bgp_Peer_Configuration
158 [Documentation] Revert the BGP configuration to the original state: without any configured peers.
159 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
160 &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} BGP_NAME=${BGP_PEER_NAME} IP=${TOOLS_SYSTEM_IP} HOLDTIME=${HOLDTIME} PEER_PORT=${BGP_TOOL_PORT}
161 ... INITIATE=false BGP_RIB=${RIB_INSTANCE} BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
162 TemplatedRequests.Delete_Templated ${BGP_VARIABLES_FOLDER} mapping=${mapping} session=${CONFIG_SESSION}