*** Settings ***
-Documentation Basic tests for eBGP application peers.
+Documentation Basic tests for eBGP application peers.
...
-... Copyright (c) 2015-2016 Cisco Systems, Inc. and others. All rights reserved.
+... Copyright (c) 2015-2016 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,
-... and is available at http://www.eclipse.org/legal/epl-v10.html
+... This program and the accompanying materials are made available under the
+... terms of the Eclipse Public License v1.0 which accompanies this distribution,
+... and is available at http://www.eclipse.org/legal/epl-v10.html
...
-... Test suite performs basic eBGP functional tests:
-... Two eBGP peers advertise the same group of prefixes (aka BGP HA)
-... https://wiki.opendaylight.org/view/BGP_LS_PCEP:BGP
-... Reported bugs:
-... Bug 4834 - ODL controller announces the same route twice (two eBGP scenario aka HA)
-... Bug 4835 - Routes not withdrawn when eBGP peers are disconnected (the same prefixes announced)
+... Test suite performs basic eBGP functional tests:
+... Two eBGP peers advertise the same group of prefixes (aka BGP HA)
+... https://wiki.opendaylight.org/view/BGP_LS_PCEP:BGP
+... Reported bugs:
+... Bug 4834 - ODL controller announces the same route twice (two eBGP scenario aka HA)
+... Bug 4835 - Routes not withdrawn when eBGP peers are disconnected (the same prefixes announced)
...
-... TODO: Extend testsuite by tests dedicated to path selection algorithm
-... TODO: Choose keywords used by more than one test suite to be placed in a common place.
-Suite Setup Setup_Everything
-Suite Teardown Teardown_Everything
-Test Setup SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
-Test Teardown FailFast.Start_Failing_Fast_If_This_Failed
-Library Collections
-Library OperatingSystem
-Library RequestsLibrary
-Variables ${CURDIR}/../../../variables/Variables.py
-Variables ${CURDIR}/../../../variables/bgpuser/variables.py ${TOOLS_SYSTEM_IP} ${ODL_STREAM}
-Resource ${CURDIR}/../../../libraries/BGPcliKeywords.robot
-Resource ${CURDIR}/../../../libraries/BGPSpeaker.robot
-Resource ${CURDIR}/../../../libraries/FailFast.robot
-Resource ${CURDIR}/../../../libraries/KillPythonTool.robot
-Resource ${CURDIR}/../../../libraries/SetupUtils.robot
-Resource ${CURDIR}/../../../libraries/SSHKeywords.robot
-Resource ${CURDIR}/../../../libraries/TemplatedRequests.robot
-Resource ${CURDIR}/../../../libraries/Utils.robot
-Resource ${CURDIR}/../../../libraries/WaitForFailure.robot
+... For versions Fluorine and above, there are test cases:
+... TC_LAS (test case local AS)
+... - configuration of ebgp with local-as and ibgp without local-as
+... - connect bgp speakers (play.py) to both peers and check their connection
+... - check adj-rib-out on both peers, expecting local-as in as-sequence on both peers.
+...
+... TODO: Extend testsuite by tests dedicated to path selection algorithm
+... TODO: Choose keywords used by more than one test suite to be placed in a common place.
+
+Library Collections
+Library OperatingSystem
+Library RequestsLibrary
+Resource ../../../libraries/BGPcliKeywords.robot
+Resource ../../../libraries/BgpOperations.robot
+Resource ../../../libraries/BGPSpeaker.robot
+Resource ../../../libraries/FailFast.robot
+Resource ../../../libraries/SetupUtils.robot
+Resource ../../../libraries/SSHKeywords.robot
+Resource ../../../libraries/TemplatedRequests.robot
+Resource ../../../variables/Variables.robot
+
+Suite Setup Setup_Everything
+Suite Teardown BgpOperations.Teardown_Everything
+Test Setup SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
+Test Teardown FailFast.Start_Failing_Fast_If_This_Failed
+
*** Variables ***
-${BGP_VARIABLES_FOLDER} ${CURDIR}/../../../variables/bgpuser/
-${HOLDTIME} 180
-${BGP_PEER_LOG_LEVEL} debug
-${ODL_LOG_LEVEL} INFO
-${ODL_BGP_LOG_LEVEL} DEFAULT
-${iBGP_PEER1_IP} 127.0.0.1
-${eBGP_PEER1_IP} 127.0.0.3
-${eBGP_PEER2_IP} 127.0.0.4
-${iBGP_PEER1_FIRST_PREFIX_IP} 8.1.0.0
-${eBGP_PEERS_FIRST_PREFIX_IP} 8.0.0.0
-${eBGP_PEER1_FIRST_PREFIX_IP} ${eBGP_PEERS_FIRST_PREFIX_IP}
-${eBGP_PEER2_FIRST_PREFIX_IP} ${eBGP_PEERS_FIRST_PREFIX_IP}
-${eBGP_PEER1_NEXT_HOP} 1.1.1.1
-${eBGP_PEER2_NEXT_HOP} 2.2.2.2
-${PREFIX_LEN} 28
-${iBGP_PEER1_PREFIX_LEN} ${PREFIX_LEN}
-${eBGP_PEER1_PREFIX_LEN} ${PREFIX_LEN}
-${eBGP_PEER2_PREFIX_LEN} ${PREFIX_LEN}
-${PREFIX_COUNT} 2
-${iBGP_PEER1_PREFIX_COUNT} 0
-${eBGP_PEER1_PREFIX_COUNT} ${PREFIX_COUNT}
-${eBGP_PEER2_PREFIX_COUNT} ${PREFIX_COUNT}
-${eBGP_PEERS_AS} 32768
-${eBGP_PEER1_AS} ${eBGP_PEERS_AS}
-${eBGP_PEER2_AS} ${eBGP_PEERS_AS}
-${iBGP_PEER1_LOG_FILE} bgp_peer1.log
-${eBGP_PEER1_LOG_FILE} ebgp_peer1.log
-${eBGP_PEER2_LOG_FILE} ebgp_peer2.log
-${iBGP_PEER1_COMMAND} python play.py --firstprefix ${iBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${iBGP_PEER1_PREFIX_LEN} --amount ${iBGP_PEER1_PREFIX_COUNT} --myip=${iBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --${BGP_PEER_LOG_LEVEL} --logfile ${iBGP_PEER1_LOG_FILE}
-${eBGP_PEER1_COMMAND} python play.py --firstprefix ${eBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${eBGP_PEER1_PREFIX_LEN} --amount ${eBGP_PEER1_PREFIX_COUNT} --myip=${eBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --nexthop ${eBGP_PEER1_NEXT_HOP} --asnumber ${eBGP_PEER1_AS} --${BGP_PEER_LOG_LEVEL} --logfile ${eBGP_PEER1_LOG_FILE}
-${eBGP_PEER2_COMMAND} python play.py --firstprefix ${eBGP_PEER2_FIRST_PREFIX_IP} --prefixlen ${eBGP_PEER2_PREFIX_LEN} --amount ${eBGP_PEER2_PREFIX_COUNT} --myip=${eBGP_PEER2_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --nexthop ${eBGP_PEER2_NEXT_HOP} --asnumber ${eBGP_PEER2_AS} --${BGP_PEER_LOG_LEVEL} --logfile ${eBGP_PEER2_LOG_FILE}
-${iBGP_PEER1_OPTIONS} &>${iBGP_PEER1_LOG_FILE}
-${eBGP_PEER1_OPTIONS} &>${eBGP_PEER1_LOG_FILE}
-${eBGP_PEER2_OPTIONS} &>${eBGP_PEER2_LOG_FILE}
-${DEFAULT_LOG_CHECK_TIMEOUT} 20s
-${DEFAULT_LOG_CHECK_PERIOD} 1s
-${DEFAULT_TOPOLOGY_CHECK_TIMEOUT} 10s
-${DEFAULT_TOPOLOGY_CHECK_PERIOD} 1s
-${RIB_INSTANCE} example-bgp-rib
-${PROTOCOL_OPENCONFIG} ${RIB_INSTANCE}
-${DEVICE_NAME} controller-config
+${BGP_VARIABLES_FOLDER} ${CURDIR}/../../../variables/bgpuser/
+${BGP_PEER_LOG_LEVEL} debug
+${CONFIG_SESSION} config-session
+${HOLDTIME} 180
+${ODL_LOG_LEVEL} INFO
+${ODL_BGP_LOG_LEVEL} DEFAULT
+${iBGP_PEER1_IP} 127.0.0.1
+${eBGP_PEER1_IP} 127.0.0.3
+${eBGP_PEER2_IP} 127.0.0.4
+${iBGP_PEER1_FIRST_PREFIX_IP} 8.1.0.0
+${eBGP_PEERS_FIRST_PREFIX_IP} 8.0.0.0
+${eBGP_PEER1_FIRST_PREFIX_IP} ${eBGP_PEERS_FIRST_PREFIX_IP}
+${eBGP_PEER2_FIRST_PREFIX_IP} ${eBGP_PEERS_FIRST_PREFIX_IP}
+${eBGP_PEER1_NEXT_HOP} 1.1.1.1
+${eBGP_PEER2_NEXT_HOP} 2.2.2.2
+${PREFIX_LEN} 28
+${iBGP_PEER1_PREFIX_LEN} ${PREFIX_LEN}
+${eBGP_PEER1_PREFIX_LEN} ${PREFIX_LEN}
+${eBGP_PEER2_PREFIX_LEN} ${PREFIX_LEN}
+${PREFIX_COUNT} 2
+${iBGP_PEER1_PREFIX_COUNT} 0
+${eBGP_PEER1_PREFIX_COUNT} ${PREFIX_COUNT}
+${eBGP_PEER2_PREFIX_COUNT} ${PREFIX_COUNT}
+${eBGP_PEERS_AS} 32768
+${eBGP_PEER1_AS} ${eBGP_PEERS_AS}
+${eBGP_PEER2_AS} ${eBGP_PEERS_AS}
+${iBGP_PEER1_LOG_FILE} bgp_peer1.log
+${eBGP_PEER1_LOG_FILE} ebgp_peer1.log
+${eBGP_PEER2_LOG_FILE} ebgp_peer2.log
+${iBGP_PEER1_COMMAND}
+... python3 play.py --firstprefix ${iBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${iBGP_PEER1_PREFIX_LEN} --amount ${iBGP_PEER1_PREFIX_COUNT} --myip=${iBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --${BGP_PEER_LOG_LEVEL} --logfile ${iBGP_PEER1_LOG_FILE}
+${eBGP_PEER1_COMMAND}
+... python3 play.py --firstprefix ${eBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${eBGP_PEER1_PREFIX_LEN} --amount ${eBGP_PEER1_PREFIX_COUNT} --myip=${eBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --nexthop ${eBGP_PEER1_NEXT_HOP} --asnumber ${eBGP_PEER1_AS} --${BGP_PEER_LOG_LEVEL} --logfile ${eBGP_PEER1_LOG_FILE}
+${eBGP_PEER2_COMMAND}
+... python3 play.py --firstprefix ${eBGP_PEER2_FIRST_PREFIX_IP} --prefixlen ${eBGP_PEER2_PREFIX_LEN} --amount ${eBGP_PEER2_PREFIX_COUNT} --myip=${eBGP_PEER2_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --nexthop ${eBGP_PEER2_NEXT_HOP} --asnumber ${eBGP_PEER2_AS} --${BGP_PEER_LOG_LEVEL} --logfile ${eBGP_PEER2_LOG_FILE}
+${iBGP_PEER1_OPTIONS} &>${iBGP_PEER1_LOG_FILE}
+${eBGP_PEER1_OPTIONS} &>${eBGP_PEER1_LOG_FILE}
+${eBGP_PEER2_OPTIONS} &>${eBGP_PEER2_LOG_FILE}
+${DEFAULT_LOG_CHECK_TIMEOUT} 20s
+${DEFAULT_LOG_CHECK_PERIOD} 1s
+${DEFAULT_TOPOLOGY_CHECK_TIMEOUT} 10s
+${DEFAULT_TOPOLOGY_CHECK_PERIOD} 1s
+${RIB_INSTANCE} example-bgp-rib
+${PROTOCOL_OPENCONFIG} ${RIB_INSTANCE}
+${DEVICE_NAME} controller-config
+${DEFAULT_AS} 64496
+${LOCAL_AS} 65432
+${eBGP_AS} 64497
+
*** Test Cases ***
Configure_BGP_Peers
[Documentation] Configure an iBGP and two eBGP peers
[Tags] critical
- &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} NAME=example-ibgp-peer1 IP=${iBGP_PEER1_IP} HOLDTIME=${HOLDTIME} PEER_PORT=${BGP_TOOL_PORT}
- ... PEER_ROLE=ibgp INITIATE=false BGP_RIB=${RIB_INSTANCE} PASSIVE_MODE=true BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG} RIB_INSTANCE_NAME=${RIB_INSTANCE}
+ &{mapping} BuiltIn.Create_Dictionary
+ ... DEVICE_NAME=${DEVICE_NAME}
+ ... NAME=example-ibgp-peer1
+ ... IP=${iBGP_PEER1_IP}
+ ... HOLDTIME=${HOLDTIME}
+ ... PEER_PORT=${BGP_TOOL_PORT}
+ ... PEER_ROLE=ibgp
+ ... INITIATE=false
+ ... BGP_RIB=${RIB_INSTANCE}
+ ... PASSIVE_MODE=true
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ ... RIB_INSTANCE_NAME=${RIB_INSTANCE}
... RR_CLIENT=false
TemplatedRequests.Put_As_Xml_Templated ${BGP_VARIABLES_FOLDER}${/}ibgp_peers mapping=${mapping}
- &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} NAME=example-ebgp-peer1 IP=${eBGP_PEER1_IP} HOLDTIME=${HOLDTIME} PEER_PORT=${BGP_TOOL_PORT}
- ... PEER_ROLE=ebgp INITIATE=false BGP_RIB=${RIB_INSTANCE} PASSIVE_MODE=true BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG} RIB_INSTANCE_NAME=${RIB_INSTANCE}
- ... RR_CLIENT=false AS_NUMBER=${eBGP_PEER1_AS}
+ &{mapping} BuiltIn.Create_Dictionary
+ ... DEVICE_NAME=${DEVICE_NAME}
+ ... NAME=example-ebgp-peer1
+ ... IP=${eBGP_PEER1_IP}
+ ... HOLDTIME=${HOLDTIME}
+ ... PEER_PORT=${BGP_TOOL_PORT}
+ ... PEER_ROLE=ebgp
+ ... INITIATE=false
+ ... BGP_RIB=${RIB_INSTANCE}
+ ... PASSIVE_MODE=true
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ ... RIB_INSTANCE_NAME=${RIB_INSTANCE}
+ ... RR_CLIENT=false
+ ... AS_NUMBER=${eBGP_PEER1_AS}
TemplatedRequests.Put_As_Xml_Templated ${BGP_VARIABLES_FOLDER}${/}ebgp_peers mapping=${mapping}
- &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} NAME=example-ebgp-peer2 IP=${eBGP_PEER2_IP} HOLDTIME=${HOLDTIME} PEER_PORT=${BGP_TOOL_PORT}
- ... PEER_ROLE=ebgp INITIATE=false BGP_RIB=${RIB_INSTANCE} PASSIVE_MODE=true BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG} RIB_INSTANCE_NAME=${RIB_INSTANCE}
- ... RR_CLIENT=false AS_NUMBER=${eBGP_PEER2_AS}
+ &{mapping} BuiltIn.Create_Dictionary
+ ... DEVICE_NAME=${DEVICE_NAME}
+ ... NAME=example-ebgp-peer2
+ ... IP=${eBGP_PEER2_IP}
+ ... HOLDTIME=${HOLDTIME}
+ ... PEER_PORT=${BGP_TOOL_PORT}
+ ... PEER_ROLE=ebgp
+ ... INITIATE=false
+ ... BGP_RIB=${RIB_INSTANCE}
+ ... PASSIVE_MODE=true
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ ... RIB_INSTANCE_NAME=${RIB_INSTANCE}
+ ... RR_CLIENT=false
+ ... AS_NUMBER=${eBGP_PEER2_AS}
TemplatedRequests.Put_As_Xml_Templated ${BGP_VARIABLES_FOLDER}${/}ebgp_peers mapping=${mapping}
Connect_iBGP_Peer1
SSHLibrary.Switch Connection ibgp_peer1_console
Start_Console_Tool ${iBGP_PEER1_COMMAND} ${iBGP_PEER1_OPTIONS}
Read_And_Fail_If_Prompt_Is_Seen
- Check_Example_IPv4_Topology_Does_Not_Contain prefix
+ BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain ${CONFIG_SESSION} prefix
Connect_eBGP_Peer1
[Documentation] Connect BGP peer
Check_IPv4_Topology_For_First_Path
[Documentation] The IPv4 topology shall contain the route announced by the first eBGP
- BuiltIn.Wait_Until_Keyword_Succeeds ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT} ${DEFAULT_TOPOLOGY_CHECK_PERIOD} Check_Example_IPv4_Topology_Content "node-id":"${eBGP_PEER1_NEXT_HOP}"
- Check_Example_IPv4_Topology_Content "prefix":"${eBGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}
+ ... ${DEFAULT_TOPOLOGY_CHECK_PERIOD}
+ ... BgpOperations.Check_Example_IPv4_Topology_Content
+ ... ${CONFIG_SESSION}
+ ... "node-id":"${eBGP_PEER1_NEXT_HOP}"
+ BgpOperations.Check_Example_IPv4_Topology_Content
+ ... ${CONFIG_SESSION}
+ ... "prefix":"${eBGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"
iBGP_Check_Log_For_Introduced_Prefixes
[Documentation] Check incomming updates for introduced routes
[Tags] critical
SSHLibrary.Switch Connection ibgp_peer1_console
- ${total_prefix_count}= BuiltIn.Evaluate ${eBGP_PEER1_PREFIX_COUNT}
- BuiltIn.Wait_Until_Keyword_Succeeds ${DEFAULT_LOG_CHECK_TIMEOUT} ${DEFAULT_LOG_CHECK_PERIOD} Check_File_For_Word_Count ${iBGP_PEER1_LOG_FILE} nlri_prefix_received: ${total_prefix_count}
- ${count}= Count_Key_Value_Pairs ${iBGP_PEER1_LOG_FILE} Network Address of Next Hop ${eBGP_PEER1_NEXT_HOP}
+ ${total_prefix_count} BuiltIn.Evaluate ${eBGP_PEER1_PREFIX_COUNT}
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_LOG_CHECK_TIMEOUT}
+ ... ${DEFAULT_LOG_CHECK_PERIOD}
+ ... Check_File_For_Word_Count
+ ... ${iBGP_PEER1_LOG_FILE}
+ ... nlri_prefix_received:
+ ... ${total_prefix_count}
+ ${count} Count_Key_Value_Pairs
+ ... ${iBGP_PEER1_LOG_FILE}
+ ... Network Address of Next Hop
+ ... ${eBGP_PEER1_NEXT_HOP}
BuiltIn.Should_Be_Equal_As_Integers ${count} ${eBGP_PEER1_PREFIX_COUNT}
- ${count}= Count_Key_Value_Pairs ${iBGP_PEER1_LOG_FILE} Network Address of Next Hop ${eBGP_PEER2_NEXT_HOP}
+ ${count} Count_Key_Value_Pairs
+ ... ${iBGP_PEER1_LOG_FILE}
+ ... Network Address of Next Hop
+ ... ${eBGP_PEER2_NEXT_HOP}
BuiltIn.Should_Be_Equal_As_Integers ${count} 0
Connect_eBGP_Peer2
Check_IPv4_Topology_For_Second_Path
[Documentation] The IPv4 topology shall contain the route announced by the second eBGP now
- BuiltIn.Wait_Until_Keyword_Succeeds ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT} ${DEFAULT_TOPOLOGY_CHECK_PERIOD} Check_Example_IPv4_Topology_Content "node-id":"${eBGP_PEER2_NEXT_HOP}"
- Check_Example_IPv4_Topology_Content "prefix":"${eBGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}
+ ... ${DEFAULT_TOPOLOGY_CHECK_PERIOD}
+ ... BgpOperations.Check_Example_IPv4_Topology_Content
+ ... ${CONFIG_SESSION}
+ ... "node-id":"${eBGP_PEER2_NEXT_HOP}"
+ BgpOperations.Check_Example_IPv4_Topology_Content
+ ... ${CONFIG_SESSION}
+ ... "prefix":"${eBGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"
iBGP_Check_Log_For_Updated_Prefixes
[Documentation] Check incomming updates for updated routes
[Tags] critical
SSHLibrary.Switch Connection ibgp_peer1_console
- ${total_prefix_count}= BuiltIn.Evaluate ${eBGP_PEER1_PREFIX_COUNT} + ${eBGP_PEER2_PREFIX_COUNT}
- BuiltIn.Wait_Until_Keyword_Succeeds ${DEFAULT_LOG_CHECK_TIMEOUT} ${DEFAULT_LOG_CHECK_PERIOD} Check_File_For_Word_Count ${iBGP_PEER1_LOG_FILE} nlri_prefix_received: ${total_prefix_count}
- ${count}= Count_Key_Value_Pairs ${iBGP_PEER1_LOG_FILE} Network Address of Next Hop ${eBGP_PEER1_NEXT_HOP}
+ ${total_prefix_count} BuiltIn.Evaluate ${eBGP_PEER1_PREFIX_COUNT} + ${eBGP_PEER2_PREFIX_COUNT}
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_LOG_CHECK_TIMEOUT}
+ ... ${DEFAULT_LOG_CHECK_PERIOD}
+ ... Check_File_For_Word_Count
+ ... ${iBGP_PEER1_LOG_FILE}
+ ... nlri_prefix_received:
+ ... ${total_prefix_count}
+ ${count} Count_Key_Value_Pairs
+ ... ${iBGP_PEER1_LOG_FILE}
+ ... Network Address of Next Hop
+ ... ${eBGP_PEER1_NEXT_HOP}
BuiltIn.Should_Be_Equal_As_Integers ${count} ${eBGP_PEER1_PREFIX_COUNT}
- ${count}= Count_Key_Value_Pairs ${iBGP_PEER1_LOG_FILE} Network Address of Next Hop ${eBGP_PEER2_NEXT_HOP}
+ ${count} Count_Key_Value_Pairs
+ ... ${iBGP_PEER1_LOG_FILE}
+ ... Network Address of Next Hop
+ ... ${eBGP_PEER2_NEXT_HOP}
BuiltIn.Should_Be_Equal_As_Integers ${count} ${eBGP_PEER2_PREFIX_COUNT}
[Teardown] Report_Failure_Due_To_Bug 4834
Check_For_Empty_IPv4_Topology
[Documentation] The IPv4 topology shall be empty
- BuiltIn.Wait_Until_Keyword_Succeeds ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT} ${DEFAULT_TOPOLOGY_CHECK_PERIOD} Check_Example_IPv4_Topology_Does_Not_Contain prefix
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}
+ ... ${DEFAULT_TOPOLOGY_CHECK_PERIOD}
+ ... BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain
+ ... ${CONFIG_SESSION}
+ ... prefix
[Teardown] Report_Failure_Due_To_Bug 4835
iBGP_Check_Log_For_Withdrawn_Prefixes
[Documentation] Check incomming updates for withdrawn routes
[Tags] critical
SSHLibrary.Switch Connection ibgp_peer1_console
- ${prefixes_to_be_removed}= BuiltIn.Evaluate max(${eBGP_PEER1_PREFIX_COUNT}, ${eBGP_PEER2_PREFIX_COUNT})
- BuiltIn.Wait_Until_Keyword_Succeeds ${DEFAULT_LOG_CHECK_TIMEOUT} ${DEFAULT_LOG_CHECK_PERIOD} Check_File_For_Word_Count ${iBGP_PEER1_LOG_FILE} withdrawn_prefix_received: ${prefixes_to_be_removed}
+ ${prefixes_to_be_removed} BuiltIn.Evaluate max(${eBGP_PEER1_PREFIX_COUNT}, ${eBGP_PEER2_PREFIX_COUNT})
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_LOG_CHECK_TIMEOUT}
+ ... ${DEFAULT_LOG_CHECK_PERIOD}
+ ... Check_File_For_Word_Count
+ ... ${iBGP_PEER1_LOG_FILE}
+ ... withdrawn_prefix_received:
+ ... ${prefixes_to_be_removed}
[Teardown] Report_Failure_Due_To_Bug 4835
Disconnect_iBGP_Peer1
Delete_BGP_Peers_Configuration
[Documentation] Delete all previously configured BGP peers.
[Tags] critical
- &{mapping} BuiltIn.Create_Dictionary DEVICE_NAME=${DEVICE_NAME} NAME=example-ibgp-peer1 IP=${iBGP_PEER1_IP} BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ &{mapping} BuiltIn.Create_Dictionary
+ ... DEVICE_NAME=${DEVICE_NAME}
+ ... NAME=example-ibgp-peer1
+ ... IP=${iBGP_PEER1_IP}
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
TemplatedRequests.Delete_Templated ${BGP_VARIABLES_FOLDER}${/}ibgp_peers mapping=${mapping}
Collections.Set To Dictionary ${mapping} NAME=example-ebgp-peer1 IP=${eBGP_PEER1_IP}
TemplatedRequests.Delete_Templated ${BGP_VARIABLES_FOLDER}${/}ebgp_peers mapping=${mapping}
Collections.Set To Dictionary ${mapping} NAME=example-ebgp-peer2 IP=${eBGP_PEER2_IP}
TemplatedRequests.Delete_Templated ${BGP_VARIABLES_FOLDER}${/}ebgp_peers mapping=${mapping}
+TC_LAS_Reconfigure_Odl_To_Accept_Connection
+ [Documentation] Configure neighbors. One ibgp and one ebgp neighbor with local-as configured.
+ &{mapping} Create Dictionary
+ ... IP=${iBGP_PEER1_IP}
+ ... HOLDTIME=${HOLDTIME}
+ ... PEER_PORT=${BGP_TOOL_PORT}
+ ... PASSIVE_MODE=true
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ TemplatedRequests.Put_As_Xml_Templated ${BGP_VARIABLES_FOLDER}${/}bgp_peer mapping=${mapping}
+ &{mapping} Create Dictionary
+ ... IP=${eBGP_PEER1_IP}
+ ... HOLDTIME=${HOLDTIME}
+ ... PEER_PORT=${BGP_TOOL_PORT}
+ ... PASSIVE_MODE=true
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ ... AS_NUMBER=${LOCAL_AS}
+ ... PEER_AS=${eBGP_AS}
+ TemplatedRequests.Put_As_Xml_Templated ${BGP_VARIABLES_FOLDER}${/}local_as/ebgp_peer mapping=${mapping}
+ [Teardown] SetupUtils.Teardown_Test_Show_Bugs_If_Test_Failed
+
+TC_LAS_Start_iBgp_Speaker_And_Verify_Connected
+ [Documentation] Verify that peer is present in odl's rib. Peer is configured with local-as.
+ [Tags] critical
+ SSHLibrary.Switch Connection ibgp_peer1_console
+ ${speaker_args} BuiltIn.Set_Variable
+ ... --firstprefix ${iBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${PREFIX_LEN} --amount 1 --myip=${iBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug
+ ${output} BGPSpeaker.Start_BGP_Speaker_And_Verify_Connected
+ ... ${speaker_args}
+ ... session=default
+ ... speaker_ip=${iBGP_PEER1_IP}
+ BuiltIn.Log ${output}
+
+TC_LAS_Start_eBgp_Speaker_And_Verify_Connected
+ [Documentation] Verify that peer is present in odl's rib. Peer is configured with local-as.
+ [Tags] critical
+ SSHLibrary.Switch Connection ebgp_peer1_console
+ ${speaker_args} BuiltIn.Set_Variable
+ ... --firstprefix ${eBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${PREFIX_LEN} --amount 1 --asnumber=${eBGP_AS} --myip=${eBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug
+ ${output} BGPSpeaker.Start_BGP_Speaker_And_Verify_Connected
+ ... ${speaker_args}
+ ... session=default
+ ... speaker_ip=${eBGP_PEER1_IP}
+ BuiltIn.Log ${output}
+
+TC_LAS_Verify_iBGP_Rib_Out
+ [Documentation] Verifies iBGP's adj-rib-out output. Expects local-as, and ebgp peer-as presence.
+ [Tags] critical
+ &{mapping} Create Dictionary
+ ... IP=${iBGP_PEER1_IP}
+ ... HOLDTIME=${HOLDTIME}
+ ... PEER_PORT=${BGP_TOOL_PORT}
+ ... PASSIVE_MODE=true
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ ... AS_NUMBER=${LOCAL_AS}
+ ... PEER_AS=${eBGP_AS}
+ ... PREFIXLEN=${eBGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}
+ ... ${DEFAULT_TOPOLOGY_CHECK_PERIOD}
+ ... TemplatedRequests.Get_As_Json_Templated
+ ... ${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out
+ ... mapping=${mapping}
+ ... verify=True
+
+TC_LAS_Verify_eBGP_Rib_Out
+ [Documentation] Verifies eBGP's adj-rib-out output. Expects local-as, and ibgp peer-as presence.
+ [Tags] critical
+ &{mapping} Create Dictionary
+ ... IP=${eBGP_PEER1_IP}
+ ... HOLDTIME=${HOLDTIME}
+ ... PEER_PORT=${BGP_TOOL_PORT}
+ ... PASSIVE_MODE=true
+ ... BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ ... AS_NUMBER=${LOCAL_AS}
+ ... PEER_AS=${DEFAULT_AS}
+ ... PREFIXLEN=${iBGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}
+ BuiltIn.Wait_Until_Keyword_Succeeds
+ ... ${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}
+ ... ${DEFAULT_TOPOLOGY_CHECK_PERIOD}
+ ... TemplatedRequests.Get_As_Json_Templated
+ ... ${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out
+ ... mapping=${mapping}
+ ... verify=True
+
+TC_LAS_Kill_iBgp_Speaker_After_Talking
+ [Documentation] Abort the Python speaker. Also, attempt to stop failing fast.
+ [Tags] critical
+ [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
+ SSHLibrary.Switch Connection ibgp_peer1_console
+ BGPSpeaker.Kill_BGP_Speaker
+ FailFast.Do_Not_Fail_Fast_From_Now_On
+ # NOTE: It is still possible to remain failing fast, if both previous and this test have failed.
+ [Teardown] FailFast.Do_Not_Start_Failing_If_This_Failed
+
+TC_LAS_Kill_eBgp_Speaker_After_Talking
+ [Documentation] Abort the Python speaker. Also, attempt to stop failing fast.
+ [Tags] critical
+ [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
+ SSHLibrary.Switch Connection ebgp_peer1_console
+ BGPSpeaker.Kill_BGP_Speaker
+ FailFast.Do_Not_Fail_Fast_From_Now_On
+ # NOTE: It is still possible to remain failing fast, if both previous and this test have failed.
+ [Teardown] FailFast.Do_Not_Start_Failing_If_This_Failed
+
+TC_LAS_Delete_Bgp_Peer_Configurations
+ [Documentation] Delete peer configuration.
+ &{mapping} Create Dictionary IP=${iBGP_PEER1_IP} BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ TemplatedRequests.Delete_Templated ${BGP_VARIABLES_FOLDER}${/}bgp_peer mapping=${mapping}
+ &{mapping} Create Dictionary IP=${eBGP_PEER1_IP} BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}
+ TemplatedRequests.Delete_Templated ${BGP_VARIABLES_FOLDER}${/}local_as/ebgp_peer mapping=${mapping}
+ [Teardown] SetupUtils.Teardown_Test_Show_Bugs_If_Test_Failed
+
+
*** Keywords ***
Setup_Everything
[Documentation] Initialize SetupUtils. SSH-login to mininet machine, create HTTP session,
SetupUtils.Setup_Utils_For_Setup_And_Teardown
SSHLibrary.Set_Default_Configuration prompt=${ODL_SYSTEM_PROMPT}
SSHLibrary.Open_Connection ${ODL_SYSTEM_IP} alias=ibgp_peer1_console
- Utils.Flexible_Controller_Login
+ SSHKeywords.Flexible_Controller_Login
SSHLibrary.Open_Connection ${ODL_SYSTEM_IP} alias=ebgp_peer1_console
- Utils.Flexible_Controller_Login
+ SSHKeywords.Flexible_Controller_Login
SSHLibrary.Open_Connection ${ODL_SYSTEM_IP} alias=ebgp_peer2_console
- Utils.Flexible_Controller_Login
+ SSHKeywords.Flexible_Controller_Login
SSHKeywords.Require_Python
SSHKeywords.Assure_Library_Ipaddr target_dir=.
SSHLibrary.Put_File ${CURDIR}/../../../../tools/fastbgp/play.py
- RequestsLibrary.Create_Session operational http://${ODL_SYSTEM_IP}:${RESTCONFPORT}${OPERATIONAL_TOPO_API} auth=${AUTH}
+ RequestsLibrary.Create_Session ${CONFIG_SESSION} http://${ODL_SYSTEM_IP}:${RESTCONFPORT} auth=${AUTH}
TemplatedRequests.Create_Default_Session
KarafKeywords.Execute_Controller_Karaf_Command_On_Background log:set ${ODL_LOG_LEVEL}
- KarafKeywords.Execute_Controller_Karaf_Command_On_Background log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.bgpcep
- KarafKeywords.Execute_Controller_Karaf_Command_On_Background log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.protocol
-
-Teardown_Everything
- [Documentation] Create and Log the diff between expected and actual responses, make sure Python tool was killed.
- ... Tear down imported Resources.
- KillPythonTool.Search_And_Kill_Remote_Python 'play\.py'
- RequestsLibrary.Delete_All_Sessions
- SSHLibrary.Close_All_Connections
+ KarafKeywords.Execute_Controller_Karaf_Command_On_Background
+ ... log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.bgpcep
+ KarafKeywords.Execute_Controller_Karaf_Command_On_Background
+ ... log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.protocol
Read_Text_Before_Prompt
[Documentation] Log text gathered by SSHLibrary.Read_Until_Prompt.
... This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.
- ${text}= SSHLibrary.Read_Until_Prompt
+ ${text} SSHLibrary.Read_Until_Prompt
BuiltIn.Log ${text}
-Check_Example_IPv4_Topology_Content
- [Arguments] ${string_to_check}=${EMPTY}
- [Documentation] Check the example-ipv4-topology content for string
- ${response}= RequestsLibrary.Get Request operational topology/example-ipv4-topology
- BuiltIn.Log ${response.status_code}
- BuiltIn.Log ${response.text}
- BuiltIn.Should_Contain ${response.text} ${string_to_check}
-
-Check_Example_IPv4_Topology_Does_Not_Contain
- [Arguments] ${string_to_check}
- [Documentation] Check the example-ipv4-topology does not contain the string
- ${response}= RequestsLibrary.Get Request operational topology/example-ipv4-topology
- BuiltIn.Log ${response.status_code}
- BuiltIn.Log ${response.text}
- BuiltIn.Should_Not_Contain ${response.text} ${string_to_check}
-
Store_File_To_Workspace
- [Arguments] ${source_file_name} ${target_file_name}
[Documentation] Store the ${source_file_name} to the workspace as ${target_file_name}.
- ${output_log}= SSHLibrary.Execute_Command cat ${source_file_name}
+ [Arguments] ${source_file_name} ${target_file_name}
+ ${output_log} SSHLibrary.Execute_Command cat ${source_file_name}
BuiltIn.Log ${output_log}
Create File ${target_file_name} ${output_log}