2 Documentation netconf-restperfclient Update performance test suite.
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
11 ... Perform given count of update operations on device data mounted onto a
12 ... netconf connector (using the netconf-testtool-restperfclient tool) and
13 ... see how much time it took. More exactly, it sends the data to a restconf
14 ... mountpoint of the netconf connector belonging to the device, which turns
15 ... out to turn the first request sent to a "create" request and the
16 ... remaining requests to "update" requests (due to how the testtool device
17 ... behavior is implemented).
18 Suite Setup Setup_Everything
19 Suite Teardown Teardown_Everything
20 Test Setup SetupUtils.Setup_Test_With_Logging_And_Fast_Failing
21 Test Teardown SetupUtils.Teardown_Test_Show_Bugs_And_Start_Fast_Failing_If_Test_Failed
23 Library RequestsLibrary
24 Library OperatingSystem
26 Library SSHLibrary timeout=10s
27 Resource ${CURDIR}/../../../libraries/KarafKeywords.robot
28 Resource ${CURDIR}/../../../libraries/NetconfKeywords.robot
29 Resource ${CURDIR}/../../../libraries/NexusKeywords.robot
30 Resource ${CURDIR}/../../../libraries/RestPerfClient.robot
31 Resource ${CURDIR}/../../../libraries/SetupUtils.robot
32 Resource ${CURDIR}/../../../libraries/TemplatedRequests.robot
33 Resource ${CURDIR}/../../../libraries/Utils.robot
34 Variables ${CURDIR}/../../../variables/Variables.py
37 ${DEVICE_NAME} ${FIRST_TESTTOOL_PORT}-sim-device
38 ${REQUEST_COUNT} 16384
39 ${directory_with_crud_templates} ${CURDIR}/../../../variables/netconf/CRUD
40 ${device_type} full-uri-device
44 [Documentation] Deploy and start test tool, then wait for all its devices to become online.
46 SSHLibrary.Switch_Connection ${testtool}
47 Run Keyword If '${IS_KARAF_APPL}' == 'True' NetconfKeywords.Install_And_Start_Testtool device-count=1 schemas=${CURDIR}/../../../variables/netconf/CRUD/schemas debug=false
48 ... ELSE NetconfKeywords.Start_Testtool ${NETCONF_FILENAME} device-count=1 schemas=${CURDIR}/../../../variables/netconf/CRUD/schemas debug=false
50 Configure_Device_On_Netconf
51 [Documentation] Configure the testtool device on Netconf connector.
52 NetconfKeywords.Configure_Device_In_Netconf ${DEVICE_NAME} device_type=${device_type}
54 Wait_For_Device_To_Become_Connected
55 [Documentation] Wait until the device becomes available through Netconf.
56 NetconfKeywords.Wait_Device_Connected ${DEVICE_NAME}
59 [Documentation] Send some sample test data into the device and check that the request went OK.
60 ${template_as_string}= BuiltIn.Create_Dictionary DEVICE_NAME=${device_name}
61 TemplatedRequests.Post_As_Xml_Templated ${directory_with_crud_templates}${/}cars ${template_as_string}
64 [Documentation] Deploy and execute restperfclient, asking it to send the specified amount of requests to the netconf connector of the device.
65 ${url}= BuiltIn.Set_Variable /rests/data/network-topology:network-topology/topology\=topology-netconf/node\=${DEVICE_NAME}/yang-ext:mount/car:cars
66 RestPerfClient.Invoke_Restperfclient ${TESTTOOL_DEVICE_TIMEOUT} ${url} async=false
68 Check_For_Failed_Requests
69 [Documentation] Make sure there are no failed requests in the restperfclient log.
70 ... This is a separate test case to distinguish between restperfclient
71 ... failure and failed requests. Failed requests are rejected because
72 ... we don't want to test performance of ODL rejecting our requests.
73 ${result}= RestPerfClient.Grep_Restperfclient_Log thread timed out
74 BuiltIn.Should_Be_Equal '${result}' ''
75 ${result}= RestPerfClient.Grep_Restperfclient_Log Request failed
76 BuiltIn.Should_Be_Equal '${result}' ''
77 ${result}= RestPerfClient.Grep_Restperfclient_Log Status code
78 BuiltIn.Should_Be_Equal '${result}' ''
81 [Documentation] Deconfigure the testtool device on Netconf connector.
82 [Setup] SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing
83 RestPerfClient.Collect_From_Restperfclient
84 NetconfKeywords.Remove_Device_From_Netconf ${DEVICE_NAME}
88 [Documentation] Setup everything needed for the test cases.
89 # Calculate and set the value of the timeout
90 ${value}= BuiltIn.Evaluate ${REQUEST_COUNT}/10+20
91 Utils.Set_User_Configurable_Variable_Default TESTTOOL_DEVICE_TIMEOUT ${value} s
92 # Setup resources used by the suite.
93 SetupUtils.Setup_Utils_For_Setup_And_Teardown
94 NetconfKeywords.Setup_Netconf_Keywords
95 Run Keyword If '${IS_KARAF_APPL}' == 'False' RestPerfClient.Setup_Restperfclient build_version=${NETCONF_TESTTOOL_VERSION} build_location=org/opendaylight/netconf
96 ... ELSE RestPerfClient.Setup_Restperfclient
97 # Connect to the tools system (testtool)
98 ${testtool}= SSHKeywords.Open_Connection_To_Tools_System
99 BuiltIn.Set_Suite_Variable ${testtool} ${testtool}
100 ${device_type}= BuiltIn.Set_Variable_If ${USE_NETCONF_CONNECTOR}==${True} default ${device_type}
101 BuiltIn.Set_Suite_Variable ${device_type}
104 [Documentation] Teardown the test infrastructure, perform cleanup and release all resources.
105 RequestsLibrary.Delete_All_Sessions
106 RestPerfClient.Teardown_Restperfclient
107 SSHLibrary.Switch_Connection ${testtool}
108 BuiltIn.Run_Keyword_And_Ignore_Error NetconfKeywords.Stop_Testtool