*** Settings ***
Documentation netconf-restperfclient Update performance test suite.
...
-... Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
+... Copyright (c) 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,
... out to turn the first request sent to a "create" request and the
... remaining requests to "update" requests (due to how the testtool device
... behavior is implemented).
-...
-... TODO: The "Wait_Until_Prompt" keyword shall probably be turned into a
-... reusable piece and moved into SSHKeywords. There is a bunch of other
-... test suites (e.g. PCEP, BGP) which contain the same or similar pieces of
-... code.
Suite Setup Setup_Everything
Suite Teardown Teardown_Everything
Test Setup SetupUtils.Setup_Test_With_Logging_And_Fast_Failing
-Test Teardown FailFast.Start_Failing_Fast_If_This_Failed
+Test Teardown SetupUtils.Teardown_Test_Show_Bugs_And_Start_Fast_Failing_If_Test_Failed
Library Collections
Library RequestsLibrary
Library OperatingSystem
Library String
Library SSHLibrary timeout=10s
-Resource ${CURDIR}/../../../libraries/FailFast.robot
Resource ${CURDIR}/../../../libraries/KarafKeywords.robot
Resource ${CURDIR}/../../../libraries/NetconfKeywords.robot
Resource ${CURDIR}/../../../libraries/NetconfViaRestconf.robot
Variables ${CURDIR}/../../../variables/Variables.py
*** Variables ***
-${DIRECTORY_WITH_CRUD_TEMPLATES} ${CURDIR}/../../../variables/netconf/CRUD
-${DIRECTORY_WITH_TEMPLATE_FOLDERS} ${CURDIR}/../../../variables/netconf/RestPerfClient
${DEVICE_NAME} ${FIRST_TESTTOOL_PORT}-sim-device
${REQUEST_COUNT} 65536
+${directory_with_crud_templates} ${CURDIR}/../../../variables/netconf/CRUD
*** Test Cases ***
Start_Testtool
Create_Device_Data
[Documentation] Send some sample test data into the device and check that the request went OK.
${template_as_string}= BuiltIn.Set_Variable {'DEVICE_NAME': '${DEVICE_NAME}'}
- NetconfViaRestconf.Post_Xml_Template_Folder_Via_Restconf ${DIRECTORY_WITH_CRUD_TEMPLATES}${/}cars ${template_as_string}
+ NetconfViaRestconf.Post_Xml_Template_Folder_Via_Restconf ${directory_with_crud_templates}${/}cars ${template_as_string}
Deploy_And_Run_RestPerfClient
[Documentation] Deploy and execute restperfclient, asking it to send the specified amount of requests to the netconf connector of the device.
+ [Timeout] ${TESTTOOL_DEVICE_TIMEOUT_FOR_TESTCASE}
SSHLibrary.Switch_Connection ${restperfclient}
SSHLibrary.Put_File ${CURDIR}/../../../variables/netconf/RestPerfClient/request1.json
${filename}= NexusKeywords.Deploy_Test_Tool netconf netconf-testtool rest-perf-client
${options}= BuiltIn.Set_Variable ${options} --destination /restconf/config/network-topology:network-topology/topology/topology-netconf/node/${DEVICE_NAME}/yang-ext:mount/car:cars
${options}= BuiltIn.Set_Variable ${options} --edit-content request1.json
${options}= BuiltIn.Set_Variable ${options} --auth ${ODL_RESTCONF_USER} ${ODL_RESTCONF_PASSWORD}
- ${command} BuiltIn.Set_Variable java -Xmx1G -XX:MaxPermSize=256M -jar ${filename} ${options}
+ ${command}= NexusKeywords.Compose_Full_Java_Command -Xmx1G -XX:MaxPermSize=256M -jar ${filename} ${options}
BuiltIn.Log Running restperfclient: ${command}
${restperfclientlog}= Utils.Get_Log_File_Name restperfclient
BuiltIn.Set_Suite_Variable ${restperfclientlog} ${restperfclientlog}
- Execute_Command_Passes ${command} >${restperfclientlog} 2>&1
+ SSHKeywords.Execute_Command_Passes ${command} >${restperfclientlog} 2>&1
SSHLibrary.Get_File ${restperfclientlog}
${result}= SSHLibrary.Execute_Command grep "FINISHED. Execution time:" ${restperfclientlog}
BuiltIn.Should_Not_Be_Equal '${result}' ''
... This is a separate test case to distinguish between restperfclient
... failure and failed requests. Failed requests are rejected because
... we don't want to test performance of ODL rejecting our requests.
+ ${result}= SSHLibrary.Execute_Command grep "thread timed out" ${restperfclientlog}
+ BuiltIn.Should_Be_Equal '${result}' ''
${result}= SSHLibrary.Execute_Command grep "Request failed" ${restperfclientlog}
BuiltIn.Should_Be_Equal '${result}' ''
+ ${result}= SSHLibrary.Execute_Command grep "Status code" ${restperfclientlog}
+ BuiltIn.Should_Be_Equal '${result}' ''
Deconfigure_Device_From_Netconf
[Documentation] Deconfigure the testtool device on Netconf connector.
*** Keywords ***
Setup_Everything
[Documentation] Setup everything needed for the test cases.
+ # Calculate and set the value of the timeout
+ ${value}= BuiltIn.Evaluate ${REQUEST_COUNT}/50+10
+ Utils.Set_User_Configurable_Variable_Default TESTTOOL_DEVICE_TIMEOUT ${value} s
+ ${value}= DateTime.Add_Time_To_Time ${TESTTOOL_DEVICE_TIMEOUT} 60s result_format=compact
+ Utils.Set_User_Configurable_Variable_Default TESTTOOL_DEVICE_TIMEOUT_FOR_TESTCASE ${value}
# Setup resources used by the suite.
SetupUtils.Setup_Utils_For_Setup_And_Teardown
- RequestsLibrary.Create_Session operational http://${ODL_SYSTEM_IP}:${RESTCONFPORT}${OPERATIONAL_API} auth=${AUTH}
NetconfKeywords.Setup_Netconf_Keywords
# Connect to the tools system (rest-perf-client)
${restperfclient}= SSHKeywords.Open_Connection_To_Tools_System
BuiltIn.Set_Suite_Variable ${restperfclient} ${restperfclient}
- # Initialize artifact deployment infrastructure.
- NexusKeywords.Initialize_Artifact_Deployment_And_Usage
${testtool}= SSHLibrary.Get Connection
BuiltIn.Set_Suite_Variable ${testtool} ${testtool.index}
RequestsLibrary.Delete_All_Sessions
SSHLibrary.Switch_Connection ${testtool}
BuiltIn.Run_Keyword_And_Ignore_Error NetconfKeywords.Stop_Testtool
-
-Wait_Until_Prompt
- [Documentation] Wait until prompt appears or timeout occurs. When timeout occurs, send Ctrl-C and then wait for the prompt again.
- ... This is necessary because the restperfclient can crash and hang, requiring that Ctrl-C character to get rid of it for good.
- ${status} ${result}= BuiltIn.Run_Keyword_And_Ignore_Error SSHLibrary.Read_Until_Prompt
- Return_From_Keyword_If '${status}' == 'PASS'
- Utils.Write_Bare_Ctrl_C
- SSHLibrary.Read_Until_Prompt