<?xml version="1.0" encoding="UTF-8"?>
<robot generator="Robot 7.4.2 (Python 3.11.10 on linux)" generated="2026-04-13T01:44:47.660162" rpa="false" schemaversion="5">
<suite id="s1" name="openflowplugin-cbench.txt" source="/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/test/csit/suites/openflowplugin/Performance/010_Cbench.robot">
<kw name="Cbench Suite Setup" type="SETUP">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Issue_Command_On_Karaf_Console" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-13T01:44:48.230836" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-04-13T01:44:48.230693" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-04-13T01:44:48.230664" elapsed="0.000272"/>
</if>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${controller}</arg>
<arg>port=${karaf_port}</arg>
<arg>prompt=${KARAF_PROMPT_LOGIN}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T01:44:48.231081" elapsed="0.000517"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-13T01:44:48.232070" level="INFO">Logging into '10.30.171.159:8101' as 'karaf'.</msg>
<msg time="2026-04-13T01:44:49.003960" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-13T01:44:48.231772" elapsed="0.772340"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-13T01:44:49.053721" level="INFO">@root&gt;log:set ERROR</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-13T01:44:49.004371" elapsed="0.049440"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-13T01:44:49.063358" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-13T01:44:49.063484" level="INFO">${output} = [?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-13T01:44:49.053997" elapsed="0.009518"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-13T01:44:49.063675" elapsed="0.000206"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T01:44:49.064042" elapsed="0.000248"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:44:49.064806" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:44:49.064471" elapsed="0.000390"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-13T01:44:49.064914" elapsed="0.000055"/>
</return>
<arg>log:set ${log_level}</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.171.159
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-13T01:44:48.230295" elapsed="0.834798"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>KarafKeywords.Issue Command On Karaf Console</arg>
<arg>log:set ${log_level}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-04-13T01:44:48.226654" elapsed="0.838516"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-13T01:44:49.065765" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv&lt;/a&gt;'.</msg>
<arg>${latency_results_file}</arg>
<arg>LATENCY_MIN,LATENCY_MAX,LATENCY_AVERAGE\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-13T01:44:49.065367" elapsed="0.000456"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-13T01:44:49.066225" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv&lt;/a&gt;'.</msg>
<arg>${throughput_results_file}</arg>
<arg>THROUGHPUT_MIN,THROUGHPUT_MAX,THROUGHPUT_AVERAGE\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-13T01:44:49.065978" elapsed="0.000333"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-13T01:44:49.066889" level="INFO">${duration_in_ms} = 60000</msg>
<var>${duration_in_ms}</var>
<arg>${duration_in_secs} * 1000</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-13T01:44:49.066485" elapsed="0.000431"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-13T01:44:49.067445" level="INFO">${duration_in_ms} = 60000</msg>
<arg>${duration_in_ms}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-13T01:44:49.067088" elapsed="0.000401"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-13T01:44:49.068010" level="INFO">${test_timeout} = 900.0</msg>
<var>${test_timeout}</var>
<arg>(${loops} * ${duration_in_secs}) * 1.5</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-13T01:44:49.067638" elapsed="0.000400"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-13T01:44:49.068529" level="INFO">${test_timeout} = 900.0</msg>
<arg>${test_timeout}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-13T01:44:49.068199" elapsed="0.000373"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="File Should Exist" owner="OperatingSystem">
<arg>${cbench_executable}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="NOT RUN" start="2026-04-13T01:44:49.068881" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-13T01:44:49.068661" elapsed="0.000275"/>
</branch>
<branch type="ELSE">
<kw name="Verify File Exists On Remote System" owner="Utils">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-13T01:44:49.073657" level="INFO">${conn_id} = 2</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T01:44:49.073224" elapsed="0.000461"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-13T01:44:49.074697" level="INFO">Length is 0.</msg>
<msg time="2026-04-13T01:44:49.074780" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-13T01:44:49.074236" elapsed="0.000568"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T01:44:49.074952" elapsed="0.000378"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-13T01:44:49.076336" level="INFO">Logging into '10.30.170.26:22' as 'jenkins'.</msg>
<msg time="2026-04-13T01:44:49.820924" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

 * Documentation:  https://help.ubuntu.com
 * Management:     https://landscape.canonical.com
 * Support:        https://ubuntu.com/pro

 System information as of Mon Apr 13 01:44:49 UTC 2026

  System load:  0.11               Processes:             109
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.170.26
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

9 additional security updates can be applied with ESM Apps.
Learn more about enabling ESM Apps service at https://ubuntu.com/esm


The list of available updates is more than a week old.
To check for new updates run: sudo apt update
New release '24.04.4 LTS' available.
Run 'do-release-upgrade' to upgrade to it.


[?2004h[jenkins@releng-48317-688-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-13T01:44:49.075853" elapsed="0.745200"/>
</kw>
<msg time="2026-04-13T01:44:49.821139" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T01:44:49.075504" elapsed="0.745719"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-13T01:44:49.073892" elapsed="0.747432"/>
</kw>
<kw name="File Should Exist" owner="SSHLibrary">
<msg time="2026-04-13T01:44:49.829899" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<arg>${file}</arg>
<doc>Fails if the given ``path`` does NOT point to an existing file.</doc>
<status status="PASS" start="2026-04-13T01:44:49.821521" elapsed="0.010519"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T01:44:49.832468" elapsed="0.000570"/>
</kw>
<arg>${cbench_system}</arg>
<arg>${cbench_executable}</arg>
<doc>Will create connection with public key and will PASS if the given ${file} exists,
otherwise will FAIL</doc>
<status status="PASS" start="2026-04-13T01:44:49.072669" elapsed="0.760503"/>
</kw>
<status status="PASS" start="2026-04-13T01:44:49.069276" elapsed="0.763978"/>
</branch>
<status status="PASS" start="2026-04-13T01:44:49.068634" elapsed="0.764680"/>
</if>
<kw name="Should Be True" owner="BuiltIn">
<arg>${loops} &gt;= 2</arg>
<arg>If number of loops is less than 2, cbench will not run</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-13T01:44:49.833680" elapsed="0.000974"/>
</kw>
<kw name="Verify_Feature_Is_Installed" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-13T01:44:49.842986" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-04-13T01:44:49.842816" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-04-13T01:44:49.842783" elapsed="0.000310"/>
</if>
<kw name="Issue_Command_On_Karaf_Console" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-13T01:44:49.848190" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-04-13T01:44:49.848031" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-04-13T01:44:49.848003" elapsed="0.000302"/>
</if>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${controller}</arg>
<arg>port=${karaf_port}</arg>
<arg>prompt=${KARAF_PROMPT_LOGIN}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T01:44:49.848509" elapsed="0.000605"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-13T01:44:49.849705" level="INFO">Logging into '10.30.171.159:8101' as 'karaf'.</msg>
<msg time="2026-04-13T01:44:50.012072" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-13T01:44:49.849323" elapsed="0.162843"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.107201" level="INFO">@root&gt;feature:list -i | 0[C 0g[Krep odl-openflowplugin-drop-test</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-13T01:44:50.012327" elapsed="0.094961"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.112427" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                                    x OpenDaylight :: Openflow Plugin :: Drop Test
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-13T01:44:50.112603" level="INFO">${output} = [?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                     ...</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-13T01:44:50.107471" elapsed="0.005166"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-13T01:44:50.112781" elapsed="0.000189"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T01:44:50.113118" elapsed="0.000192"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:44:50.113741" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                                    x OpenDaylight :: Openflow Plugin :: Drop Test
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:44:50.113471" elapsed="0.000333"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-13T01:44:50.113849" elapsed="0.000035"/>
</return>
<msg time="2026-04-13T01:44:50.114018" level="INFO">${output} = [?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                     ...</msg>
<var>${output}</var>
<arg>feature:list -i | grep ${feature_name}</arg>
<arg>${controller}</arg>
<arg>${karaf_port}</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.171.159
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-13T01:44:49.847530" elapsed="0.266520"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>${feature_name}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-13T01:44:50.114196" elapsed="0.000520"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-13T01:44:50.114768" elapsed="0.000031"/>
</return>
<arg>odl-openflowplugin-drop-test</arg>
<doc>Will Succeed if the given ${feature_name} is found in the output of "feature:list -i"</doc>
<status status="PASS" start="2026-04-13T01:44:49.842392" elapsed="0.272505"/>
</kw>
<kw name="Issue_Command_On_Karaf_Console" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-13T01:44:50.118549" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-04-13T01:44:50.118431" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-04-13T01:44:50.118409" elapsed="0.000210"/>
</if>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${controller}</arg>
<arg>port=${karaf_port}</arg>
<arg>prompt=${KARAF_PROMPT_LOGIN}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T01:44:50.118747" elapsed="0.000411"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.119574" level="INFO">Logging into '10.30.171.159:8101' as 'karaf'.</msg>
<msg time="2026-04-13T01:44:50.295952" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-13T01:44:50.119305" elapsed="0.176740"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.316928" level="INFO">@root&gt;dropallpacketsrpc on</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-13T01:44:50.296205" elapsed="0.020811"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.318885" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-13T01:44:50.318992" level="INFO">${output} = [?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-13T01:44:50.317199" elapsed="0.001824"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-13T01:44:50.319161" elapsed="0.000186"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T01:44:50.319510" elapsed="0.000191"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:44:50.320104" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:44:50.319841" elapsed="0.000312"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-13T01:44:50.320199" elapsed="0.000044"/>
</return>
<arg>dropallpacketsrpc on</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.171.159
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-13T01:44:50.118107" elapsed="0.202240"/>
</kw>
<status status="PASS" start="2026-04-13T01:44:48.224546" elapsed="2.095920"/>
</kw>
<test id="s1-t1" name="Cbench Latency Test" line="37">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:44:50.323003" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:44:50.321302" elapsed="0.001776"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-13T01:44:50.324537" level="INFO">${output_filename} = latency.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-13T01:44:50.324166" elapsed="0.000416"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-13T01:44:50.324884" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-13T01:44:50.324657" elapsed="0.000285"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-13T01:44:50.327933" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-13T01:44:50.327683" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-04-13T01:44:50.327649" elapsed="0.000366"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.328347" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-04-13T01:44:50.328487" level="INFO">${current_ssh_connection} = index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-13T01:44:50.328148" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:44:50.329075" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.159 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.170.26" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:44:50.328651" elapsed="0.000484"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.329758" level="INFO">${conn_id} = 5</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T01:44:50.329276" elapsed="0.000509"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-13T01:44:50.330702" level="INFO">Length is 0.</msg>
<msg time="2026-04-13T01:44:50.330794" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-13T01:44:50.330366" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T01:44:50.330962" elapsed="0.000329"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.332201" level="INFO">Logging into '10.30.170.26:22' as 'jenkins'.</msg>
<msg time="2026-04-13T01:44:50.642519" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

 * Documentation:  https://help.ubuntu.com
 * Management:     https://landscape.canonical.com
 * Support:        https://ubuntu.com/pro

 System information as of Mon Apr 13 01:44:49 UTC 2026

  System load:  0.11               Processes:             109
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.170.26
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

9 additional security updates can be applied with ESM Apps.
Learn more about enabling ESM Apps service at https://ubuntu.com/esm


The list of available updates is more than a week old.
To check for new updates run: sudo apt update
New release '24.04.4 LTS' available.
Run 'do-release-upgrade' to upgrade to it.


Last login: Mon Apr 13 01:44:49 2026 from 10.30.171.129
[?2004h[jenkins@releng-48317-688-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-13T01:44:50.331839" elapsed="0.310793"/>
</kw>
<msg time="2026-04-13T01:44:50.642695" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T01:44:50.331462" elapsed="0.311298"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-13T01:44:50.329987" elapsed="0.312865"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-13T01:44:50.643426" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.159 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-13T01:54:56.753039" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-13T01:54:56.753664" level="INFO">${stdout} = </msg>
<msg time="2026-04-13T01:54:56.753773" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-13T01:44:50.643013" elapsed="606.110828"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T01:54:56.754310" elapsed="0.000731"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.756183" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100 unique source MACs per switch
   learning destination mac addresses before the test
   starting test with 5000 ms delay after features_reply
   ignoring first 1 "warmup" and last 0 "cooldown" loops
   debugging info is off
Master Thread: Creating thread-0! 
Thread-0: All switches initialized. Running at node 10.30.171.159. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:45:55.853 16  switches: flows:  115418 117069 115240 117464 115597 114581 115769 114383 111244 110500 112290 111542 111664 113074 112151 113268  total = 30.354233 per ms 
01:46:55.954 16  switches: flows:  127535 127974 125245 126576 123873 125022 124511 123105 120849 121352 118719 120588 121251 123489 120013 121796  total = 32.810163 per ms 
01:47:56.054 16  switches: flows:  127640 129388 126886 129581 126885 126554 127225 124909 120285 121515 122921 123198 123204 124961 123780 123124  total = 33.311959 per ms 
01:48:56.156 16  switches: flows:  129463 131208 128723 131039 130023 129563 128564 127550 123938 125139 125350 125529 126886 127322 123402 125386  total = 33.928146 per ms 
01:49:56.256 16  switches: flows:  129732 132050 126377 131957 128767 130605 126803 128739 125979 125263 126766 124062 123633 126919 125551 123353  total = 33.886033 per ms 
01:50:56.358 16  switches: flows:  125757 128697 123285 129213 126051 125689 124341 126750 123724 121954 122387 120339 120687 124256 123146 119595  total = 33.042131 per ms 
01:51:56.460 16  switches: flows:  129760 131812 128225 132322 130910 127513 126787 129628 126019 124620 126996 123069 125360 126624 126130 123389  total = 33.928860 per ms 
01:52:56.561 16  switches: flows:  125085 127735 121842 128404 126278 124217 122953 124886 122632 122004 121519 121468 121217 124062 122055 119450  total = 32.875205 per ms 
01:53:56.662 16  switches: flows:  123062 127370 121394 128275 124605 123974 122373 123521 120633 119741 121679 119841 120239 122228 122474 118541  total = 32.611376 per ms 
01:54:56.763 16  switches: flows:  113947 115784 112661 115194 113648 113315 111263 113934 110736 109058 109443 108374 109255 111780 111173 107892  total = 29.741281 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29741.28/33928.86/32903.91/11035.37 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.755457" elapsed="0.001088"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-13T01:54:56.757051" elapsed="0.000085"/>
</return>
<status status="PASS" start="2026-04-13T01:54:56.756750" elapsed="0.000468"/>
</branch>
<status status="PASS" start="2026-04-13T01:54:56.756693" elapsed="0.000582"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-13T01:54:56.757523" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-04-13T01:54:56.757437" elapsed="0.000178"/>
</branch>
<status status="NOT RUN" start="2026-04-13T01:54:56.757372" elapsed="0.000292"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-13T01:54:56.757740" elapsed="0.000031"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T01:54:56.761789" elapsed="0.000329"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T01:54:56.762266" elapsed="0.000194"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T01:54:56.762595" elapsed="0.000101"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-13T01:54:56.758441" elapsed="0.004308"/>
</kw>
<msg time="2026-04-13T01:54:56.762878" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-13T01:44:50.325294" elapsed="606.437611"/>
</kw>
<status status="PASS" start="2026-04-13T01:44:50.324970" elapsed="606.437984"/>
</branch>
<status status="PASS" start="2026-04-13T01:44:50.324635" elapsed="606.438342"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.763433" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100 unique source MACs per switch
   learning destination mac addresses before the test
   starting test with 5000 ms delay after features_reply
   ignoring first 1 "warmup" and last 0 "cooldown" loops
   debugging info is off
Master Thread: Creating thread-0! 
Thread-0: All switches initialized. Running at node 10.30.171.159. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:45:55.853 16  switches: flows:  115418 117069 115240 117464 115597 114581 115769 114383 111244 110500 112290 111542 111664 113074 112151 113268  total = 30.354233 per ms 
01:46:55.954 16  switches: flows:  127535 127974 125245 126576 123873 125022 124511 123105 120849 121352 118719 120588 121251 123489 120013 121796  total = 32.810163 per ms 
01:47:56.054 16  switches: flows:  127640 129388 126886 129581 126885 126554 127225 124909 120285 121515 122921 123198 123204 124961 123780 123124  total = 33.311959 per ms 
01:48:56.156 16  switches: flows:  129463 131208 128723 131039 130023 129563 128564 127550 123938 125139 125350 125529 126886 127322 123402 125386  total = 33.928146 per ms 
01:49:56.256 16  switches: flows:  129732 132050 126377 131957 128767 130605 126803 128739 125979 125263 126766 124062 123633 126919 125551 123353  total = 33.886033 per ms 
01:50:56.358 16  switches: flows:  125757 128697 123285 129213 126051 125689 124341 126750 123724 121954 122387 120339 120687 124256 123146 119595  total = 33.042131 per ms 
01:51:56.460 16  switches: flows:  129760 131812 128225 132322 130910 127513 126787 129628 126019 124620 126996 123069 125360 126624 126130 123389  total = 33.928860 per ms 
01:52:56.561 16  switches: flows:  125085 127735 121842 128404 126278 124217 122953 124886 122632 122004 121519 121468 121217 124062 122055 119450  total = 32.875205 per ms 
01:53:56.662 16  switches: flows:  123062 127370 121394 128275 124605 123974 122373 123521 120633 119741 121679 119841 120239 122228 122474 118541  total = 32.611376 per ms 
01:54:56.763 16  switches: flows:  113947 115784 112661 115194 113648 113315 111263 113934 110736 109058 109443 108374 109255 111780 111173 107892  total = 29.741281 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29741.28/33928.86/32903.91/11035.37 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.763117" elapsed="0.000395"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-13T01:54:56.763670" elapsed="0.000367"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-13T01:54:56.764441" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-13T01:54:56.764535" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 29741.28/33928.86/32903.91/11035.37 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-13T01:54:56.764199" elapsed="0.000361"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T01:54:56.764972" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 29741.28/33928.86/32903.91/11035.37 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T01:54:56.764716" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.767451" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.765145" elapsed="0.002365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.769892" level="INFO">29741.28/33928.86/32903.91/11035.37</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.767660" elapsed="0.002289"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T01:54:56.772316" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T01:54:56.770097" elapsed="0.002246"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T01:54:56.774796" level="INFO">@{result_value_list} = [ 29741.28 | 33928.86 | 32903.91 | 11035.37 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T01:54:56.772553" elapsed="0.002271"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.775286" level="INFO">Length is 4.</msg>
<msg time="2026-04-13T01:54:56.775429" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-13T01:54:56.774980" elapsed="0.000475"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.780233" level="INFO">min :: 29741.28</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.775867" elapsed="0.004424"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-13T01:54:56.775733" elapsed="0.004594"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.784923" level="INFO">max :: 33928.86</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.780569" elapsed="0.004411"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-13T01:54:56.780436" elapsed="0.004579"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.789597" level="INFO">avg :: 32903.91</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.785235" elapsed="0.004421"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-13T01:54:56.785106" elapsed="0.004585"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.794347" level="INFO">stdev :: 11035.37</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.789912" elapsed="0.004507"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-13T01:54:56.789784" elapsed="0.004670"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-13T01:54:56.775525" elapsed="0.018963"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.798429" level="INFO">${min} = 29741.28</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T01:54:56.794671" elapsed="0.003786"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.802486" level="INFO">${max} = 33928.86</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T01:54:56.798612" elapsed="0.003901"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.806808" level="INFO">${average} = 32903.91</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T01:54:56.802679" elapsed="0.004156"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.810804" level="INFO">${stdev} = 11035.37</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T01:54:56.806990" elapsed="0.003840"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.811345" level="INFO">${date} = 2026-04-13 01:54:56</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-13T01:54:56.810991" elapsed="0.000406"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.811967" level="INFO">CBench Result: 2026-04-13 01:54:56,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,29741.28,33928.86,32903.91,11035.37</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.811551" elapsed="0.000473"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-13T01:54:56.813113" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-13T01:54:56.812697" elapsed="0.000483"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-13T01:54:56.813332" elapsed="0.000486"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-13T01:54:56.812175" elapsed="0.001709"/>
</kw>
<arg>-m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${latency_threshold}</arg>
<arg>${latency_results_file}</arg>
<status status="PASS" start="2026-04-13T01:44:50.323515" elapsed="606.490430"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.814454" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-13T01:54:56.814097" elapsed="0.000414"/>
</kw>
<kw name="Log Results As Zero If Cbench Timed Out" type="TEARDOWN">
<kw name="Run Keyword If Timeout Occurred" owner="BuiltIn">
<arg>Log Results And Determine Status</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>${output_filename}</arg>
<doc>Runs the given keyword if either a test or a keyword timeout has occurred.</doc>
<status status="PASS" start="2026-04-13T01:54:56.815028" elapsed="0.000269"/>
</kw>
<status status="PASS" start="2026-04-13T01:54:56.814721" elapsed="0.000688"/>
</kw>
<doc>cbench executed in default latency mode. Test parameters have defaults, but can be overridden
on the pybot command line</doc>
<tag>cbench</tag>
<tag>latency</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-13T01:44:50.320626" elapsed="606.494822"/>
</test>
<test id="s1-t2" name="Cbench Throughput Test" line="51">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.816707" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.816308" elapsed="0.000457"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.818188" level="INFO">${output_filename} = throughput.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-13T01:54:56.817854" elapsed="0.000377"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-13T01:54:56.818597" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-04-13T01:54:56.818353" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-13T01:54:56.821588" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-13T01:54:56.821324" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-04-13T01:54:56.821305" elapsed="0.000363"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-13T01:54:56.822007" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-04-13T01:54:56.822126" level="INFO">${current_ssh_connection} = index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-13T01:54:56.821801" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.822730" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.159 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.170.26" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T01:54:56.822289" elapsed="0.000499"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-13T01:54:56.823324" level="INFO">${conn_id} = 7</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T01:54:56.822929" elapsed="0.000421"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-13T01:54:56.824294" level="INFO">Length is 0.</msg>
<msg time="2026-04-13T01:54:56.824398" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-13T01:54:56.823979" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T01:54:56.824572" elapsed="0.000325"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-13T01:54:56.825770" level="INFO">Logging into '10.30.170.26:22' as 'jenkins'.</msg>
<msg time="2026-04-13T01:54:57.425545" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

 * Documentation:  https://help.ubuntu.com
 * Management:     https://landscape.canonical.com
 * Support:        https://ubuntu.com/pro

 System information as of Mon Apr 13 01:54:57 UTC 2026

  System load:  1.0                Processes:             105
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.170.26
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

9 additional security updates can be applied with ESM Apps.
Learn more about enabling ESM Apps service at https://ubuntu.com/esm


The list of available updates is more than a week old.
To check for new updates run: sudo apt update
New release '24.04.4 LTS' available.
Run 'do-release-upgrade' to upgrade to it.


Last login: Mon Apr 13 01:44:50 2026 from 10.30.171.129
[?2004h[jenkins@releng-48317-688-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-13T01:54:56.825411" elapsed="0.600332"/>
</kw>
<msg time="2026-04-13T01:54:57.425835" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T01:54:56.825050" elapsed="0.600883"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-13T01:54:56.823601" elapsed="0.602453"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-13T01:54:57.426630" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.159 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-13T02:05:03.607947" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-13T02:05:03.608566" level="INFO">${stdout} = </msg>
<msg time="2026-04-13T02:05:03.608675" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-13T01:54:57.426290" elapsed="606.182444"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T02:05:03.609193" elapsed="0.000789"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.611134" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100 unique source MACs per switch
   learning destination mac addresses before the test
   starting test with 5000 ms delay after features_reply
   ignoring first 1 "warmup" and last 0 "cooldown" loops
   debugging info is off
Master Thread: Creating thread-0! 
Thread-0: All switches initialized. Running at node 10.30.171.159. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:56:02.577 16  switches: flows:  515109 529013 528206 520346 529859 526379 527739 521814 519634 502846 516720 512285 512581 515456 504145 517277  total = 138.323483 per ms 
01:57:02.678 16  switches: flows:  558998 554847 559003 552151 544529 556704 560245 557087 557577 550636 560504 552210 555166 564024 562173 553674  total = 148.076779 per ms 
01:58:02.782 16  switches: flows:  580147 561511 589884 585413 581638 589000 579597 582152 578603 589824 571769 571728 584936 579140 569513 566318  total = 154.086799 per ms 
01:59:02.883 16  switches: flows:  553976 555884 560168 565946 559331 564810 550613 575267 551474 563245 564223 564502 562117 550816 577023 550985  total = 149.256786 per ms 
02:00:02.985 16  switches: flows:  584075 584010 583560 599179 593568 592813 581765 598955 597857 598922 594572 585040 580852 589773 595686 595769  total = 157.337930 per ms 
02:01:03.197 16  switches: flows:  478796 479801 491513 487085 474273 484010 482683 481168 481845 472859 489086 482861 491838 493335 479049 482917  total = 128.435917 per ms 
02:02:03.299 16  switches: flows:  540744 543557 539873 543625 547858 549306 543025 531567 548033 546885 537997 544715 547351 557838 542144 542383  total = 144.870593 per ms 
02:03:03.407 16  switches: flows:  588505 599899 590903 598099 590785 598995 587952 599520 594977 590637 600551 597995 593301 597195 592761 591549  total = 158.275275 per ms 
02:04:03.509 16  switches: flows:  584912 589877 598094 586444 591142 584555 594078 591002 588882 588217 589339 594851 595195 594135 588821 577563  total = 157.020119 per ms 
02:05:03.610 16  switches: flows:  545926 542630 545577 540223 548116 546391 546827 551056 543026 545616 538245 542422 553700 546037 533721 546757  total = 145.027506 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 128435.92/158275.28/149154.19/50496.58 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.610359" elapsed="0.001120"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-13T02:05:03.611982" elapsed="0.000084"/>
</return>
<status status="PASS" start="2026-04-13T02:05:03.611676" elapsed="0.000474"/>
</branch>
<status status="PASS" start="2026-04-13T02:05:03.611622" elapsed="0.000585"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-13T02:05:03.612454" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-04-13T02:05:03.612337" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-04-13T02:05:03.612301" elapsed="0.000298"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-13T02:05:03.612670" elapsed="0.000031"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T02:05:03.618302" elapsed="0.000351"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T02:05:03.618802" elapsed="0.000176"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T02:05:03.619111" elapsed="0.000104"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-13T02:05:03.613345" elapsed="0.005924"/>
</kw>
<msg time="2026-04-13T02:05:03.619413" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-13T01:54:56.818996" elapsed="606.800445"/>
</kw>
<status status="PASS" start="2026-04-13T01:54:56.818683" elapsed="606.800809"/>
</branch>
<status status="PASS" start="2026-04-13T01:54:56.818329" elapsed="606.801187"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.619949" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100 unique source MACs per switch
   learning destination mac addresses before the test
   starting test with 5000 ms delay after features_reply
   ignoring first 1 "warmup" and last 0 "cooldown" loops
   debugging info is off
Master Thread: Creating thread-0! 
Thread-0: All switches initialized. Running at node 10.30.171.159. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:56:02.577 16  switches: flows:  515109 529013 528206 520346 529859 526379 527739 521814 519634 502846 516720 512285 512581 515456 504145 517277  total = 138.323483 per ms 
01:57:02.678 16  switches: flows:  558998 554847 559003 552151 544529 556704 560245 557087 557577 550636 560504 552210 555166 564024 562173 553674  total = 148.076779 per ms 
01:58:02.782 16  switches: flows:  580147 561511 589884 585413 581638 589000 579597 582152 578603 589824 571769 571728 584936 579140 569513 566318  total = 154.086799 per ms 
01:59:02.883 16  switches: flows:  553976 555884 560168 565946 559331 564810 550613 575267 551474 563245 564223 564502 562117 550816 577023 550985  total = 149.256786 per ms 
02:00:02.985 16  switches: flows:  584075 584010 583560 599179 593568 592813 581765 598955 597857 598922 594572 585040 580852 589773 595686 595769  total = 157.337930 per ms 
02:01:03.197 16  switches: flows:  478796 479801 491513 487085 474273 484010 482683 481168 481845 472859 489086 482861 491838 493335 479049 482917  total = 128.435917 per ms 
02:02:03.299 16  switches: flows:  540744 543557 539873 543625 547858 549306 543025 531567 548033 546885 537997 544715 547351 557838 542144 542383  total = 144.870593 per ms 
02:03:03.407 16  switches: flows:  588505 599899 590903 598099 590785 598995 587952 599520 594977 590637 600551 597995 593301 597195 592761 591549  total = 158.275275 per ms 
02:04:03.509 16  switches: flows:  584912 589877 598094 586444 591142 584555 594078 591002 588882 588217 589339 594851 595195 594135 588821 577563  total = 157.020119 per ms 
02:05:03.610 16  switches: flows:  545926 542630 545577 540223 548116 546391 546827 551056 543026 545616 538245 542422 553700 546037 533721 546757  total = 145.027506 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 128435.92/158275.28/149154.19/50496.58 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.619658" elapsed="0.000365"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-13T02:05:03.620173" elapsed="0.000387"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-13T02:05:03.620939" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-13T02:05:03.621030" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 128435.92/158275.28/149154.19/50496.58 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-13T02:05:03.620720" elapsed="0.000335"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T02:05:03.621480" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 128435.92/158275.28/149154.19/50496.58 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T02:05:03.621209" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.623915" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.621652" elapsed="0.002319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.626352" level="INFO">128435.92/158275.28/149154.19/50496.58</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.624116" elapsed="0.002308"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T02:05:03.628783" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T02:05:03.626574" elapsed="0.002237"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T02:05:03.631278" level="INFO">@{result_value_list} = [ 128435.92 | 158275.28 | 149154.19 | 50496.58 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T02:05:03.628999" elapsed="0.002308"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.631786" level="INFO">Length is 4.</msg>
<msg time="2026-04-13T02:05:03.631877" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-13T02:05:03.631477" elapsed="0.000425"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.636670" level="INFO">min :: 128435.92</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.632275" elapsed="0.004452"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-13T02:05:03.632144" elapsed="0.004618"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.641552" level="INFO">max :: 158275.28</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.636981" elapsed="0.004629"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-13T02:05:03.636852" elapsed="0.004794"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.646311" level="INFO">avg :: 149154.19</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.641864" elapsed="0.004504"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-13T02:05:03.641736" elapsed="0.004683"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.651065" level="INFO">stdev :: 50496.58</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.646655" elapsed="0.004467"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-13T02:05:03.646509" elapsed="0.004648"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-13T02:05:03.631963" elapsed="0.019226"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.655495" level="INFO">${min} = 128435.92</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:05:03.651346" elapsed="0.004177"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.659487" level="INFO">${max} = 158275.28</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:05:03.655679" elapsed="0.003835"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.663479" level="INFO">${average} = 149154.19</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:05:03.659668" elapsed="0.003839"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.667499" level="INFO">${stdev} = 50496.58</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:05:03.663660" elapsed="0.003865"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.668033" level="INFO">${date} = 2026-04-13 02:05:03</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-13T02:05:03.667684" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.668638" level="INFO">CBench Result: 2026-04-13 02:05:03,-t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,128435.92,158275.28,149154.19,50496.58</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.668207" elapsed="0.000486"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-13T02:05:03.669710" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-13T02:05:03.669302" elapsed="0.000473"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-13T02:05:03.669953" elapsed="0.000478"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-13T02:05:03.668829" elapsed="0.001667"/>
</kw>
<arg>-t -m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${throughput_threshold}</arg>
<arg>${throughput_results_file}</arg>
<status status="PASS" start="2026-04-13T01:54:56.817077" elapsed="606.853480"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.671022" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-13T02:05:03.670706" elapsed="0.000372"/>
</kw>
<kw name="Log Results As Zero If Cbench Timed Out" type="TEARDOWN">
<kw name="Run Keyword If Timeout Occurred" owner="BuiltIn">
<arg>Log Results And Determine Status</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>${output_filename}</arg>
<doc>Runs the given keyword if either a test or a keyword timeout has occurred.</doc>
<status status="PASS" start="2026-04-13T02:05:03.671599" elapsed="0.000267"/>
</kw>
<status status="PASS" start="2026-04-13T02:05:03.671279" elapsed="0.000658"/>
</kw>
<doc>cbench executed in throughput mode (-t). Test parameters have defaults, but can be overridden
on the pybot command line</doc>
<tag>cbench</tag>
<tag>throughput</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-13T01:54:56.815749" elapsed="606.856226"/>
</test>
<test id="s1-t3" name="Rerun Latency Test To Check Bug 6176" line="65">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.673542" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.673136" elapsed="0.000463"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.674875" level="INFO">${output_filename} = bug.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-13T02:05:03.674534" elapsed="0.000384"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-13T02:05:03.675246" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-04-13T02:05:03.675026" elapsed="0.000279"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-13T02:05:03.678891" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-13T02:05:03.678641" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-04-13T02:05:03.678620" elapsed="0.000350"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-13T02:05:03.679290" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-04-13T02:05:03.679422" level="INFO">${current_ssh_connection} = index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-13T02:05:03.679101" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.680015" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.159 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.170.26" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:05:03.679591" elapsed="0.000482"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-13T02:05:03.680619" level="INFO">${conn_id} = 9</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T02:05:03.680212" elapsed="0.000439"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-13T02:05:03.681689" level="INFO">Length is 0.</msg>
<msg time="2026-04-13T02:05:03.681784" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-13T02:05:03.681226" elapsed="0.000582"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T02:05:03.681982" elapsed="0.000327"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-13T02:05:03.683184" level="INFO">Logging into '10.30.170.26:22' as 'jenkins'.</msg>
<msg time="2026-04-13T02:05:04.295503" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

 * Documentation:  https://help.ubuntu.com
 * Management:     https://landscape.canonical.com
 * Support:        https://ubuntu.com/pro

 System information as of Mon Apr 13 02:05:03 UTC 2026

  System load:  0.54               Processes:             106
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.170.26
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

9 additional security updates can be applied with ESM Apps.
Learn more about enabling ESM Apps service at https://ubuntu.com/esm


The list of available updates is more than a week old.
To check for new updates run: sudo apt update
New release '24.04.4 LTS' available.
Run 'do-release-upgrade' to upgrade to it.


Last login: Mon Apr 13 01:54:57 2026 from 10.30.171.129
[?2004h[jenkins@releng-48317-688-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-13T02:05:03.682828" elapsed="0.613023"/>
</kw>
<msg time="2026-04-13T02:05:04.296019" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T02:05:03.682478" elapsed="0.613695"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-13T02:05:03.680852" elapsed="0.615586"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-13T02:05:04.297512" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.159 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-13T02:15:10.351240" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-13T02:15:10.351893" level="INFO">${stdout} = </msg>
<msg time="2026-04-13T02:15:10.352008" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-13T02:05:04.296885" elapsed="606.055184"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T02:15:10.352598" elapsed="0.000725"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.354573" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100 unique source MACs per switch
   learning destination mac addresses before the test
   starting test with 5000 ms delay after features_reply
   ignoring first 1 "warmup" and last 0 "cooldown" loops
   debugging info is off
Master Thread: Creating thread-0! 
Thread-0: All switches initialized. Running at node 10.30.171.159. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:06:09.452 16  switches: flows:  123688 121472 121551 124250 121122 122227 122345 121712 122345 119672 118566 118782 119559 118885 121009 119918  total = 32.285050 per ms 
02:07:09.552 16  switches: flows:  125581 126119 123024 128018 124951 127738 125816 126105 124608 123675 123597 121941 125244 123272 121559 123115  total = 33.183990 per ms 
02:08:09.653 16  switches: flows:  119378 119170 118686 121444 117090 119176 119371 117242 118469 117819 117569 115994 116812 116978 115881 115114  total = 31.384154 per ms 
02:09:09.755 16  switches: flows:  123648 121914 126238 126403 123669 121648 122843 122083 123211 123724 123344 120667 121950 122769 122248 118548  total = 32.692966 per ms 
02:10:09.855 16  switches: flows:  127077 124295 125020 128436 126572 123966 123555 126208 126707 126829 124086 120429 123192 126031 124377 120905  total = 33.239231 per ms 
02:11:09.955 16  switches: flows:  127454 126122 126767 129535 126194 124910 126530 128573 126860 127480 125167 122164 125211 127906 126668 124148  total = 33.638603 per ms 
02:12:10.056 16  switches: flows:  128635 125767 127076 129729 124889 125549 125325 127083 127191 127441 125255 122326 124671 126895 126368 123973  total = 33.580147 per ms 
02:13:10.156 16  switches: flows:  130368 128024 127499 131013 127204 128285 127630 128307 129149 128771 126000 124188 127692 128081 127332 123950  total = 34.001448 per ms 
02:14:10.256 16  switches: flows:  127326 127291 126658 129475 125765 125687 125154 127775 127229 126546 126408 122558 125271 127346 125613 124600  total = 33.622182 per ms 
02:15:10.357 16  switches: flows:  126584 127787 128243 131158 126149 126565 128103 128693 128197 125849 126848 124516 127246 128320 129115 124035  total = 33.900208 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 31384.15/34001.45/33249.21/11109.02 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.353752" elapsed="0.001209"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-13T02:15:10.355539" elapsed="0.000083"/>
</return>
<status status="PASS" start="2026-04-13T02:15:10.355176" elapsed="0.000498"/>
</branch>
<status status="PASS" start="2026-04-13T02:15:10.355120" elapsed="0.000590"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-13T02:15:10.355840" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-04-13T02:15:10.355789" elapsed="0.000107"/>
</branch>
<status status="NOT RUN" start="2026-04-13T02:15:10.355767" elapsed="0.000159"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-13T02:15:10.355967" elapsed="0.000018"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-13T02:15:10.359578" elapsed="0.000466"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-13T02:15:10.360250" elapsed="0.000260"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-13T02:15:10.360696" elapsed="0.000138"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-13T02:15:10.356421" elapsed="0.004488"/>
</kw>
<msg time="2026-04-13T02:15:10.361086" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-13T02:05:03.675842" elapsed="606.685282"/>
</kw>
<status status="PASS" start="2026-04-13T02:05:03.675330" elapsed="606.685862"/>
</branch>
<status status="PASS" start="2026-04-13T02:05:03.675005" elapsed="606.686219"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.361854" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.159:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100 unique source MACs per switch
   learning destination mac addresses before the test
   starting test with 5000 ms delay after features_reply
   ignoring first 1 "warmup" and last 0 "cooldown" loops
   debugging info is off
Master Thread: Creating thread-0! 
Thread-0: All switches initialized. Running at node 10.30.171.159. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:06:09.452 16  switches: flows:  123688 121472 121551 124250 121122 122227 122345 121712 122345 119672 118566 118782 119559 118885 121009 119918  total = 32.285050 per ms 
02:07:09.552 16  switches: flows:  125581 126119 123024 128018 124951 127738 125816 126105 124608 123675 123597 121941 125244 123272 121559 123115  total = 33.183990 per ms 
02:08:09.653 16  switches: flows:  119378 119170 118686 121444 117090 119176 119371 117242 118469 117819 117569 115994 116812 116978 115881 115114  total = 31.384154 per ms 
02:09:09.755 16  switches: flows:  123648 121914 126238 126403 123669 121648 122843 122083 123211 123724 123344 120667 121950 122769 122248 118548  total = 32.692966 per ms 
02:10:09.855 16  switches: flows:  127077 124295 125020 128436 126572 123966 123555 126208 126707 126829 124086 120429 123192 126031 124377 120905  total = 33.239231 per ms 
02:11:09.955 16  switches: flows:  127454 126122 126767 129535 126194 124910 126530 128573 126860 127480 125167 122164 125211 127906 126668 124148  total = 33.638603 per ms 
02:12:10.056 16  switches: flows:  128635 125767 127076 129729 124889 125549 125325 127083 127191 127441 125255 122326 124671 126895 126368 123973  total = 33.580147 per ms 
02:13:10.156 16  switches: flows:  130368 128024 127499 131013 127204 128285 127630 128307 129149 128771 126000 124188 127692 128081 127332 123950  total = 34.001448 per ms 
02:14:10.256 16  switches: flows:  127326 127291 126658 129475 125765 125687 125154 127775 127229 126546 126408 122558 125271 127346 125613 124600  total = 33.622182 per ms 
02:15:10.357 16  switches: flows:  126584 127787 128243 131158 126149 126565 128103 128693 128197 125849 126848 124516 127246 128320 129115 124035  total = 33.900208 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 31384.15/34001.45/33249.21/11109.02 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.361448" elapsed="0.000507"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-13T02:15:10.362163" elapsed="0.000525"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-13T02:15:10.363230" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-13T02:15:10.363355" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 31384.15/34001.45/33249.21/11109.02 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-13T02:15:10.362926" elapsed="0.000484"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T02:15:10.363981" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 31384.15/34001.45/33249.21/11109.02 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T02:15:10.363629" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.367483" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.364220" elapsed="0.003342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.370128" level="INFO">31384.15/34001.45/33249.21/11109.02</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.367732" elapsed="0.002453"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T02:15:10.372588" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T02:15:10.370336" elapsed="0.002279"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-13T02:15:10.375083" level="INFO">@{result_value_list} = [ 31384.15 | 34001.45 | 33249.21 | 11109.02 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-13T02:15:10.372808" elapsed="0.002303"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.375586" level="INFO">Length is 4.</msg>
<msg time="2026-04-13T02:15:10.375673" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-13T02:15:10.375265" elapsed="0.000432"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.380428" level="INFO">min :: 31384.15</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.376077" elapsed="0.004408"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-13T02:15:10.375948" elapsed="0.004572"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.385178" level="INFO">max :: 34001.45</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.380733" elapsed="0.004500"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-13T02:15:10.380607" elapsed="0.004661"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.390073" level="INFO">avg :: 33249.21</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.385647" elapsed="0.004485"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-13T02:15:10.385350" elapsed="0.004817"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.395151" level="INFO">stdev :: 11109.02</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.390404" elapsed="0.004803"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-13T02:15:10.390252" elapsed="0.004991"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-13T02:15:10.375762" elapsed="0.019511"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.399658" level="INFO">${min} = 31384.15</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:15:10.395457" elapsed="0.004231"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.403625" level="INFO">${max} = 34001.45</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:15:10.399845" elapsed="0.003807"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.407581" level="INFO">${average} = 33249.21</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:15:10.403806" elapsed="0.003802"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.411553" level="INFO">${stdev} = 11109.02</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-13T02:15:10.407765" elapsed="0.003815"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.412104" level="INFO">${date} = 2026-04-13 02:15:10</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-13T02:15:10.411742" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.412716" level="INFO">CBench Result: 2026-04-13 02:15:10,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,31384.15,34001.45,33249.21,11109.02</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-13T02:15:10.412288" elapsed="0.000484"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-13T02:15:10.413940" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/bug.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/bug.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-13T02:15:10.413430" elapsed="0.000578"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-13T02:15:10.414161" elapsed="0.000483"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-13T02:15:10.412927" elapsed="0.001784"/>
</kw>
<arg>-m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${latency_threshold}</arg>
<arg>bug.csv</arg>
<status status="PASS" start="2026-04-13T02:05:03.673922" elapsed="606.740849"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.415254" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-13T02:15:10.414920" elapsed="0.000392"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-13T02:15:10.416555" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-13T02:15:10.416059" elapsed="0.000523"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-04-13T02:15:10.416823" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-04-13T02:15:10.416670" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-04-13T02:15:10.416645" elapsed="0.000273"/>
</if>
<kw name="Comment" owner="BuiltIn">
<arg>Jira tickets are {PROJECT}-{NUMBER} while Bugzilla tickets are {NUMBER}</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.417067" elapsed="0.000021"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<var>${match}</var>
<arg>Should Contain</arg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.417230" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${bug_url}</var>
<arg>${match}</arg>
<arg>https://jira.opendaylight.org/browse/${number}</arg>
<arg>https://bugs.opendaylight.org/show_bug.cgi?id=${number}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.417411" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>This test fails due to ${bug_url}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.417614" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.417772" elapsed="0.000026"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.417927" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.418073" elapsed="0.000019"/>
</kw>
<if>
<branch type="IF" condition="&quot;${include_bug_in_tags}&quot;==&quot;True&quot;">
<kw name="Set Tags" owner="BuiltIn">
<arg>${bug_url}</arg>
<doc>Adds given ``tags`` for the current test or all tests in a suite.</doc>
<status status="NOT RUN" start="2026-04-13T02:15:10.418294" elapsed="0.000019"/>
</kw>
<status status="NOT RUN" start="2026-04-13T02:15:10.418155" elapsed="0.000190"/>
</branch>
<status status="NOT RUN" start="2026-04-13T02:15:10.418138" elapsed="0.000229"/>
</if>
<arg>6176</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-04-13T02:15:10.415714" elapsed="0.002721"/>
</kw>
<doc>cbench executed in latency mode to see if controller is healthy</doc>
<tag>cbench</tag>
<tag>latency</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-13T02:05:03.672550" elapsed="606.745930"/>
</test>
<doc>Cbench Latency and Throughput tests can be run from an external
cbench.
If cbench is run with a medium number of switches or higher (e.g. 32+)
the normal openflow operations seem to break.
BUG: https://bugs.opendaylight.org/show_bug.cgi?id=2897</doc>
<status status="PASS" start="2026-04-13T01:44:47.661741" elapsed="1822.757392"/>
</suite>
<statistics>
<total>
<stat pass="3" fail="0" skip="0">All Tests</stat>
</total>
<tag>
<stat pass="3" fail="0" skip="0">cbench</stat>
<stat pass="2" fail="0" skip="0">latency</stat>
<stat pass="1" fail="0" skip="0">throughput</stat>
</tag>
<suite>
<stat name="openflowplugin-cbench.txt" id="s1" pass="3" fail="0" skip="0">openflowplugin-cbench.txt</stat>
</suite>
</statistics>
<errors>
</errors>
</robot>
