<?xml version="1.0" encoding="UTF-8"?>
<robot generator="Robot 7.4.2 (Python 3.11.10 on linux)" generated="2026-05-08T01:54:51.836146" 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-05-08T01:54:52.402650" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-05-08T01:54:52.402505" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-05-08T01:54:52.402474" elapsed="0.000277"/>
</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-05-08T01:54:52.402895" elapsed="0.000529"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-05-08T01:54:52.403899" level="INFO">Logging into '10.30.171.193:8101' as 'karaf'.</msg>
<msg time="2026-05-08T01:54:52.991822" 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-05-08T01:54:52.403602" elapsed="0.588510"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-05-08T01:54:53.041544" 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-05-08T01:54:52.992654" elapsed="0.048959"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-05-08T01:54:53.043301" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-05-08T01:54:53.043413" 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-05-08T01:54:53.041783" elapsed="0.001659"/>
</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-05-08T01:54:53.043598" elapsed="0.000209"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T01:54:53.043982" elapsed="0.000224"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T01:54:53.044710" 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-05-08T01:54:53.044360" elapsed="0.000405"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-05-08T01:54:53.044822" elapsed="0.000059"/>
</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.193
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-05-08T01:54:52.402105" elapsed="0.642906"/>
</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-05-08T01:54:52.398475" elapsed="0.646601"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-05-08T01:54:53.045660" 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-05-08T01:54:53.045292" elapsed="0.000425"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-05-08T01:54:53.046115" 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-05-08T01:54:53.045869" elapsed="0.000324"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-05-08T01:54:53.046776" 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-05-08T01:54:53.046351" elapsed="0.000453"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-05-08T01:54:53.047336" 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-05-08T01:54:53.046975" elapsed="0.000404"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-05-08T01:54:53.047921" 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-05-08T01:54:53.047527" elapsed="0.000421"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-05-08T01:54:53.048445" 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-05-08T01:54:53.048107" elapsed="0.000379"/>
</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-05-08T01:54:53.048796" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-05-08T01:54:53.048577" elapsed="0.000273"/>
</branch>
<branch type="ELSE">
<kw name="Verify File Exists On Remote System" owner="Utils">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-05-08T01:54:53.053311" 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-05-08T01:54:53.052876" elapsed="0.000462"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-05-08T01:54:53.054652" level="INFO">Length is 0.</msg>
<msg time="2026-05-08T01:54:53.054738" 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-05-08T01:54:53.053886" elapsed="0.000876"/>
</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-05-08T01:54:53.054912" elapsed="0.000366"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-05-08T01:54:53.056339" level="INFO">Logging into '10.30.171.120:22' as 'jenkins'.</msg>
<msg time="2026-05-08T01:54:53.741026" 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 Fri May  8 01:54:53 UTC 2026

  System load:  0.06               Processes:             111
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.120
  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-713-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-05-08T01:54:53.055799" elapsed="0.685310"/>
</kw>
<msg time="2026-05-08T01:54:53.741192" 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-05-08T01:54:53.055437" elapsed="0.685824"/>
</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-05-08T01:54:53.053544" elapsed="0.687808"/>
</kw>
<kw name="File Should Exist" owner="SSHLibrary">
<msg time="2026-05-08T01:54:53.748537" 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-05-08T01:54:53.741503" elapsed="0.008756"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T01:54:53.750426" elapsed="0.000282"/>
</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-05-08T01:54:53.052333" elapsed="0.698435"/>
</kw>
<status status="PASS" start="2026-05-08T01:54:53.048933" elapsed="0.701871"/>
</branch>
<status status="PASS" start="2026-05-08T01:54:53.048551" elapsed="0.702281"/>
</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-05-08T01:54:53.751011" elapsed="0.000512"/>
</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-05-08T01:54:53.761146" elapsed="0.000066"/>
</return>
<status status="NOT RUN" start="2026-05-08T01:54:53.760888" elapsed="0.000401"/>
</branch>
<status status="PASS" start="2026-05-08T01:54:53.760841" elapsed="0.000503"/>
</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-05-08T01:54:53.766032" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-05-08T01:54:53.765919" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-05-08T01:54:53.765900" elapsed="0.000202"/>
</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-05-08T01:54:53.766251" elapsed="0.000421"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-05-08T01:54:53.767102" level="INFO">Logging into '10.30.171.193:8101' as 'karaf'.</msg>
<msg time="2026-05-08T01:54:53.964398" 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-05-08T01:54:53.766834" elapsed="0.197648"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.053336" 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-05-08T01:54:53.964637" elapsed="0.088759"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.058235" 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-05-08T01:54:54.058388" 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-05-08T01:54:54.053537" elapsed="0.004883"/>
</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-05-08T01:54:54.058561" elapsed="0.000176"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T01:54:54.058884" elapsed="0.000168"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T01:54:54.059476" 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-05-08T01:54:54.059207" elapsed="0.000324"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-05-08T01:54:54.059576" elapsed="0.000035"/>
</return>
<msg time="2026-05-08T01:54:54.059743" 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.193
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-05-08T01:54:53.765567" elapsed="0.294207"/>
</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-05-08T01:54:54.059919" elapsed="0.000487"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-05-08T01:54:54.060458" elapsed="0.000030"/>
</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-05-08T01:54:53.760266" elapsed="0.300320"/>
</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-05-08T01:54:54.064229" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-05-08T01:54:54.064092" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-05-08T01:54:54.064072" elapsed="0.000228"/>
</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-05-08T01:54:54.064428" elapsed="0.000427"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.065279" level="INFO">Logging into '10.30.171.193:8101' as 'karaf'.</msg>
<msg time="2026-05-08T01:54:54.231325" 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-05-08T01:54:54.064999" elapsed="0.166422"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.253812" 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-05-08T01:54:54.231597" elapsed="0.022421"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.258291" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-05-08T01:54:54.258520" 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-05-08T01:54:54.254510" elapsed="0.004074"/>
</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-05-08T01:54:54.258889" elapsed="0.000448"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T01:54:54.259715" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T01:54:54.260857" 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-05-08T01:54:54.260366" elapsed="0.000561"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-05-08T01:54:54.261004" elapsed="0.000077"/>
</return>
<arg>dropallpacketsrpc on</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.171.193
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-05-08T01:54:54.063787" elapsed="0.197489"/>
</kw>
<status status="PASS" start="2026-05-08T01:54:52.396607" elapsed="1.864760"/>
</kw>
<test id="s1-t1" name="Cbench Latency Test" line="37">
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T01:54:54.264580" 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-05-08T01:54:54.262846" elapsed="0.001824"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-05-08T01:54:54.266731" 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-05-08T01:54:54.266231" elapsed="0.000561"/>
</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-05-08T01:54:54.267275" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-05-08T01:54:54.266909" elapsed="0.000450"/>
</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-05-08T01:54:54.271566" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-05-08T01:54:54.271188" elapsed="0.000456"/>
</branch>
<status status="PASS" start="2026-05-08T01:54:54.271143" elapsed="0.000537"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.272149" 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-05-08T01:54:54.272344" 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-05-08T01:54:54.271865" elapsed="0.000506"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T01:54:54.272947" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.193 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.120" 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-05-08T01:54:54.272508" elapsed="0.000500"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.273642" 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-05-08T01:54:54.273149" elapsed="0.000519"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-05-08T01:54:54.274633" level="INFO">Length is 0.</msg>
<msg time="2026-05-08T01:54:54.274724" 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-05-08T01:54:54.274293" elapsed="0.000455"/>
</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-05-08T01:54:54.274892" elapsed="0.000355"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.276132" level="INFO">Logging into '10.30.171.120:22' as 'jenkins'.</msg>
<msg time="2026-05-08T01:54:54.595655" 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 Fri May  8 01:54:53 UTC 2026

  System load:  0.06               Processes:             111
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.120
  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: Fri May  8 01:54:53 2026 from 10.30.171.179
[?2004h[jenkins@releng-48317-713-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-05-08T01:54:54.275775" elapsed="0.320082"/>
</kw>
<msg time="2026-05-08T01:54:54.595951" 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-05-08T01:54:54.275415" elapsed="0.320631"/>
</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-05-08T01:54:54.273870" elapsed="0.322322"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-05-08T01:54:54.597124" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.193 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-05-08T02:05:00.692697" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-05-08T02:05:00.693293" level="INFO">${stdout} = </msg>
<msg time="2026-05-08T02:05:00.693411" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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-05-08T01:54:54.596460" elapsed="606.097012"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T02:05:00.693937" elapsed="0.000766"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.695859" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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.193. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:55:59.792 16  switches: flows:  97617 99249 96054 94301 97917 95919 96072 94262 94966 94627 96872 95366 94827 95251 94522 93999  total = 25.530350 per ms 
01:56:59.892 16  switches: flows:  117051 120688 116009 115793 118711 114901 117234 117145 113980 111781 117186 115654 112929 115109 116309 112276  total = 30.827789 per ms 
01:57:59.993 16  switches: flows:  120131 120933 117850 118308 120704 114831 118368 119404 116171 112605 117893 117686 116146 114379 117072 113660  total = 31.216880 per ms 
01:59:00.093 16  switches: flows:  121901 123386 119856 120171 122368 117546 120022 120042 119081 114924 120312 115343 115323 117151 117814 114550  total = 31.610394 per ms 
02:00:00.193 16  switches: flows:  119383 123050 119358 121098 122225 117175 120316 120538 116745 114665 117952 116931 114946 115627 116784 115153  total = 31.479868 per ms 
02:01:00.293 16  switches: flows:  120506 124045 121728 120557 125206 119031 120994 121355 119900 114997 118841 119930 115959 118517 119045 116883  total = 31.904971 per ms 
02:02:00.394 16  switches: flows:  120145 123520 119489 119280 124052 117865 120502 120071 118721 115210 120610 120418 115742 116971 121606 115618  total = 31.777202 per ms 
02:03:00.494 16  switches: flows:  123451 122020 119040 121912 122622 118873 120422 120129 117537 115722 118411 117237 117512 116482 118299 116938  total = 31.723838 per ms 
02:04:00.594 16  switches: flows:  96880 94514 95792 95706 94685 92484 94515 93497 91461 91320 93416 94035 93473 92148 92903 92771  total = 24.951673 per ms 
02:05:00.694 16  switches: flows:  117175 114600 113582 115206 114903 112912 115823 114096 111444 112207 113493 113680 111986 112274 112013 111354  total = 30.228682 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 24951.67/31904.97/30635.70/10419.83 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:05:00.695067" elapsed="0.001173"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-05-08T02:05:00.696743" elapsed="0.000073"/>
</return>
<status status="PASS" start="2026-05-08T02:05:00.696438" elapsed="0.000462"/>
</branch>
<status status="PASS" start="2026-05-08T02:05:00.696381" elapsed="0.000579"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-05-08T02:05:00.697210" elapsed="0.000033"/>
</return>
<status status="NOT RUN" start="2026-05-08T02:05:00.697093" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-05-08T02:05:00.697057" elapsed="0.000299"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-05-08T02:05:00.697445" elapsed="0.000032"/>
</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-05-08T02:05:00.701590" elapsed="0.000458"/>
</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-05-08T02:05:00.702296" elapsed="0.000234"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T02:05:00.702711" elapsed="0.000134"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-05-08T02:05:00.698128" elapsed="0.004791"/>
</kw>
<msg time="2026-05-08T02:05:00.703102" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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-05-08T01:54:54.267869" elapsed="606.435270"/>
</kw>
<status status="PASS" start="2026-05-08T01:54:54.267401" elapsed="606.435828"/>
</branch>
<status status="PASS" start="2026-05-08T01:54:54.266876" elapsed="606.436386"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.703858" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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.193. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:55:59.792 16  switches: flows:  97617 99249 96054 94301 97917 95919 96072 94262 94966 94627 96872 95366 94827 95251 94522 93999  total = 25.530350 per ms 
01:56:59.892 16  switches: flows:  117051 120688 116009 115793 118711 114901 117234 117145 113980 111781 117186 115654 112929 115109 116309 112276  total = 30.827789 per ms 
01:57:59.993 16  switches: flows:  120131 120933 117850 118308 120704 114831 118368 119404 116171 112605 117893 117686 116146 114379 117072 113660  total = 31.216880 per ms 
01:59:00.093 16  switches: flows:  121901 123386 119856 120171 122368 117546 120022 120042 119081 114924 120312 115343 115323 117151 117814 114550  total = 31.610394 per ms 
02:00:00.193 16  switches: flows:  119383 123050 119358 121098 122225 117175 120316 120538 116745 114665 117952 116931 114946 115627 116784 115153  total = 31.479868 per ms 
02:01:00.293 16  switches: flows:  120506 124045 121728 120557 125206 119031 120994 121355 119900 114997 118841 119930 115959 118517 119045 116883  total = 31.904971 per ms 
02:02:00.394 16  switches: flows:  120145 123520 119489 119280 124052 117865 120502 120071 118721 115210 120610 120418 115742 116971 121606 115618  total = 31.777202 per ms 
02:03:00.494 16  switches: flows:  123451 122020 119040 121912 122622 118873 120422 120129 117537 115722 118411 117237 117512 116482 118299 116938  total = 31.723838 per ms 
02:04:00.594 16  switches: flows:  96880 94514 95792 95706 94685 92484 94515 93497 91461 91320 93416 94035 93473 92148 92903 92771  total = 24.951673 per ms 
02:05:00.694 16  switches: flows:  117175 114600 113582 115206 114903 112912 115823 114096 111444 112207 113493 113680 111986 112274 112013 111354  total = 30.228682 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 24951.67/31904.97/30635.70/10419.83 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:05:00.703458" elapsed="0.000501"/>
</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-05-08T02:05:00.704183" elapsed="0.000516"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-05-08T02:05:00.705273" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-05-08T02:05:00.705404" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 24951.67/31904.97/30635.70/10419.83 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-05-08T02:05:00.704925" elapsed="0.000514"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:05:00.706011" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 24951.67/31904.97/30635.70/10419.83 | 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-05-08T02:05:00.705654" elapsed="0.000394"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.708762" 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-05-08T02:05:00.706301" elapsed="0.002517"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.711192" level="INFO">24951.67/31904.97/30635.70/10419.83</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:05:00.708963" elapsed="0.002287"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:05:00.713597" 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-05-08T02:05:00.711400" elapsed="0.002224"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:05:00.716046" level="INFO">@{result_value_list} = [ 24951.67 | 31904.97 | 30635.70 | 10419.83 ]</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-05-08T02:05:00.713819" elapsed="0.002254"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.716574" level="INFO">Length is 4.</msg>
<msg time="2026-05-08T02:05:00.716666" 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-05-08T02:05:00.716243" elapsed="0.000446"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.721491" level="INFO">min :: 24951.67</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-05-08T02:05:00.717139" elapsed="0.004413"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-05-08T02:05:00.716996" elapsed="0.004594"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.726239" level="INFO">max :: 31904.97</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-05-08T02:05:00.721835" elapsed="0.004472"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-05-08T02:05:00.721693" elapsed="0.004650"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.730998" level="INFO">avg :: 30635.70</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-05-08T02:05:00.726572" elapsed="0.004483"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-05-08T02:05:00.726436" elapsed="0.004655"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.735702" level="INFO">stdev :: 10419.83</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-05-08T02:05:00.731332" elapsed="0.004427"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-05-08T02:05:00.731199" elapsed="0.004594"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-05-08T02:05:00.716766" elapsed="0.019060"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.740130" level="INFO">${min} = 24951.67</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-05-08T02:05:00.735997" elapsed="0.004182"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.744046" level="INFO">${max} = 31904.97</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-05-08T02:05:00.740340" elapsed="0.003733"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.748180" level="INFO">${average} = 30635.70</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-05-08T02:05:00.744240" elapsed="0.003967"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.752119" level="INFO">${stdev} = 10419.83</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-05-08T02:05:00.748376" elapsed="0.003769"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.752687" level="INFO">${date} = 2026-05-08 02:05:00</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-05-08T02:05:00.752322" elapsed="0.000391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.753285" level="INFO">CBench Result: 2026-05-08 02:05:00,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,24951.67,31904.97,30635.70,10419.83</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-05-08T02:05:00.752860" elapsed="0.000480"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-05-08T02:05:00.754490" 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-05-08T02:05:00.754007" elapsed="0.000549"/>
</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-05-08T02:05:00.754709" elapsed="0.000495"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-05-08T02:05:00.753508" elapsed="0.001764"/>
</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-05-08T01:54:54.265305" elapsed="606.490028"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.755803" 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-05-08T02:05:00.755485" elapsed="0.000375"/>
</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-05-08T02:05:00.756397" elapsed="0.000271"/>
</kw>
<status status="PASS" start="2026-05-08T02:05:00.756077" elapsed="0.000662"/>
</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-05-08T01:54:54.261583" elapsed="606.495193"/>
</test>
<test id="s1-t2" name="Cbench Throughput Test" line="51">
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.758306" 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-05-08T02:05:00.757877" elapsed="0.000485"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.759602" 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-05-08T02:05:00.759273" elapsed="0.000371"/>
</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-05-08T02:05:00.759991" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-05-08T02:05:00.759766" elapsed="0.000284"/>
</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-05-08T02:05:00.762959" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-05-08T02:05:00.762708" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-05-08T02:05:00.762689" elapsed="0.000350"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-05-08T02:05:00.763407" 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-05-08T02:05:00.763525" 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-05-08T02:05:00.763187" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.764100" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.193 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.120" 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-05-08T02:05:00.763687" elapsed="0.000484"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-05-08T02:05:00.764707" 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-05-08T02:05:00.764313" elapsed="0.000420"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-05-08T02:05:00.765633" level="INFO">Length is 0.</msg>
<msg time="2026-05-08T02:05:00.765722" 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-05-08T02:05:00.765321" elapsed="0.000425"/>
</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-05-08T02:05:00.765887" elapsed="0.000342"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-05-08T02:05:00.767136" level="INFO">Logging into '10.30.171.120:22' as 'jenkins'.</msg>
<msg time="2026-05-08T02:05:01.363492" 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 Fri May  8 02:05:00 UTC 2026

  System load:  1.04               Processes:             104
  Usage of /:   19.6% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.120
  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: Fri May  8 01:54:54 2026 from 10.30.171.179
[?2004h[jenkins@releng-48317-713-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-05-08T02:05:00.766759" elapsed="0.596942"/>
</kw>
<msg time="2026-05-08T02:05:01.363799" 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-05-08T02:05:00.766417" elapsed="0.597480"/>
</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-05-08T02:05:00.764933" elapsed="0.599087"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-05-08T02:05:01.364627" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.193 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-05-08T02:15:07.836750" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-05-08T02:15:07.837350" level="INFO">${stdout} = </msg>
<msg time="2026-05-08T02:15:07.837479" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.193: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-05-08T02:05:01.364290" elapsed="606.473256"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T02:15:07.838044" elapsed="0.000753"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.839987" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.193: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.193. 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:06.509 16  switches: flows:  505933 503004 520847 496726 522631 518204 518727 514192 509858 493573 487001 512630 480863 490169 496408 486882  total = 134.294133 per ms 
02:07:07.026 16  switches: flows:  562988 557499 558173 562633 562811 554911 561602 556010 556458 558982 562167 557074 564093 560430 568746 555330  total = 148.055513 per ms 
02:08:07.127 16  switches: flows:  565228 571314 512293 526510 523654 532467 569515 553063 565577 571984 572878 503067 537988 581627 528360 569859  total = 146.176389 per ms 
02:09:07.228 16  switches: flows:  569450 569238 573003 561579 566829 561137 556952 566875 563570 576506 560962 563733 571861 570528 576990 564058  total = 150.967470 per ms 
02:10:07.330 16  switches: flows:  613041 613530 606672 610249 604205 617103 611163 610349 604923 614437 617517 606067 618857 614016 616827 612704  total = 162.921817 per ms 
02:11:07.432 16  switches: flows:  596160 612249 603119 604609 594694 596309 586351 599857 603722 596289 596242 600452 599071 606720 610243 599788  total = 159.826071 per ms 
02:12:07.534 16  switches: flows:  598751 600498 589001 581127 592697 587084 601903 593299 598994 587754 598979 591091 586601 583589 592671 590245  total = 157.639612 per ms 
02:13:07.635 16  switches: flows:  580664 597551 605210 591542 586901 587312 585676 588881 588687 593328 584003 577322 592511 584930 588428 571018  total = 156.468016 per ms 
02:14:07.737 16  switches: flows:  534553 534185 532424 531782 529441 538128 495580 535846 542967 535158 532490 536327 536755 512496 535117 532697  total = 141.360947 per ms 
02:15:07.838 16  switches: flows:  528319 536994 579990 526394 583646 552411 545143 511007 583464 533656 526823 555199 578833 512306 524829 511994  total = 144.606796 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 141360.95/162921.82/152002.51/51159.29 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:15:07.839206" elapsed="0.001186"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-05-08T02:15:07.840964" elapsed="0.000074"/>
</return>
<status status="PASS" start="2026-05-08T02:15:07.840585" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-05-08T02:15:07.840532" elapsed="0.000684"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-05-08T02:15:07.841445" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-05-08T02:15:07.841359" elapsed="0.000181"/>
</branch>
<status status="NOT RUN" start="2026-05-08T02:15:07.841320" elapsed="0.000271"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-05-08T02:15:07.841679" elapsed="0.000033"/>
</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-05-08T02:15:07.846958" elapsed="0.000491"/>
</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-05-08T02:15:07.847671" elapsed="0.000235"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T02:15:07.848092" elapsed="0.000169"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-05-08T02:15:07.842633" elapsed="0.005703"/>
</kw>
<msg time="2026-05-08T02:15:07.848514" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.193: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-05-08T02:05:00.760411" elapsed="607.088140"/>
</kw>
<status status="PASS" start="2026-05-08T02:05:00.760077" elapsed="607.088563"/>
</branch>
<status status="PASS" start="2026-05-08T02:05:00.759743" elapsed="607.088932"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.849339" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.193: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.193. 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:06.509 16  switches: flows:  505933 503004 520847 496726 522631 518204 518727 514192 509858 493573 487001 512630 480863 490169 496408 486882  total = 134.294133 per ms 
02:07:07.026 16  switches: flows:  562988 557499 558173 562633 562811 554911 561602 556010 556458 558982 562167 557074 564093 560430 568746 555330  total = 148.055513 per ms 
02:08:07.127 16  switches: flows:  565228 571314 512293 526510 523654 532467 569515 553063 565577 571984 572878 503067 537988 581627 528360 569859  total = 146.176389 per ms 
02:09:07.228 16  switches: flows:  569450 569238 573003 561579 566829 561137 556952 566875 563570 576506 560962 563733 571861 570528 576990 564058  total = 150.967470 per ms 
02:10:07.330 16  switches: flows:  613041 613530 606672 610249 604205 617103 611163 610349 604923 614437 617517 606067 618857 614016 616827 612704  total = 162.921817 per ms 
02:11:07.432 16  switches: flows:  596160 612249 603119 604609 594694 596309 586351 599857 603722 596289 596242 600452 599071 606720 610243 599788  total = 159.826071 per ms 
02:12:07.534 16  switches: flows:  598751 600498 589001 581127 592697 587084 601903 593299 598994 587754 598979 591091 586601 583589 592671 590245  total = 157.639612 per ms 
02:13:07.635 16  switches: flows:  580664 597551 605210 591542 586901 587312 585676 588881 588687 593328 584003 577322 592511 584930 588428 571018  total = 156.468016 per ms 
02:14:07.737 16  switches: flows:  534553 534185 532424 531782 529441 538128 495580 535846 542967 535158 532490 536327 536755 512496 535117 532697  total = 141.360947 per ms 
02:15:07.838 16  switches: flows:  528319 536994 579990 526394 583646 552411 545143 511007 583464 533656 526823 555199 578833 512306 524829 511994  total = 144.606796 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 141360.95/162921.82/152002.51/51159.29 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:15:07.848898" elapsed="0.000545"/>
</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-05-08T02:15:07.849656" elapsed="0.000534"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-05-08T02:15:07.850731" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-05-08T02:15:07.850858" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 141360.95/162921.82/152002.51/51159.29 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-05-08T02:15:07.850420" elapsed="0.000472"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:15:07.851491" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 141360.95/162921.82/152002.51/51159.29 | 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-05-08T02:15:07.851109" elapsed="0.000420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.854974" 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-05-08T02:15:07.851735" elapsed="0.003320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.858273" level="INFO">141360.95/162921.82/152002.51/51159.29</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:15:07.855286" elapsed="0.003046"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:15:07.860776" 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-05-08T02:15:07.858486" elapsed="0.002320"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:15:07.863229" level="INFO">@{result_value_list} = [ 141360.95 | 162921.82 | 152002.51 | 51159.29 ]</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-05-08T02:15:07.860999" elapsed="0.002258"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.863734" level="INFO">Length is 4.</msg>
<msg time="2026-05-08T02:15:07.863825" 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-05-08T02:15:07.863414" elapsed="0.000434"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.868589" level="INFO">min :: 141360.95</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-05-08T02:15:07.864256" elapsed="0.004417"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-05-08T02:15:07.864106" elapsed="0.004603"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.874694" level="INFO">max :: 162921.82</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-05-08T02:15:07.868933" elapsed="0.005818"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-05-08T02:15:07.868801" elapsed="0.005986"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.879504" level="INFO">avg :: 152002.51</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-05-08T02:15:07.875020" elapsed="0.004550"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-05-08T02:15:07.874877" elapsed="0.004729"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.884570" level="INFO">stdev :: 51159.29</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-05-08T02:15:07.879833" elapsed="0.004796"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-05-08T02:15:07.879696" elapsed="0.005011"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-05-08T02:15:07.863918" elapsed="0.020821"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.888693" level="INFO">${min} = 141360.95</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-05-08T02:15:07.884902" elapsed="0.003822"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.892609" level="INFO">${max} = 162921.82</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-05-08T02:15:07.888884" elapsed="0.003787"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.896562" level="INFO">${average} = 152002.51</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-05-08T02:15:07.892840" elapsed="0.003749"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.900508" level="INFO">${stdev} = 51159.29</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-05-08T02:15:07.896777" elapsed="0.003764"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.901127" level="INFO">${date} = 2026-05-08 02:15:07</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-05-08T02:15:07.900756" elapsed="0.000396"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.901726" level="INFO">CBench Result: 2026-05-08 02:15:07,-t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,141360.95,162921.82,152002.51,51159.29</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-05-08T02:15:07.901318" elapsed="0.000464"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-05-08T02:15:07.902819" 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-05-08T02:15:07.902409" elapsed="0.000477"/>
</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-05-08T02:15:07.903041" elapsed="0.000476"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-05-08T02:15:07.901924" elapsed="0.001658"/>
</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-05-08T02:05:00.758683" elapsed="607.144959"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.904115" 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-05-08T02:15:07.903793" elapsed="0.000394"/>
</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-05-08T02:15:07.904718" elapsed="0.000264"/>
</kw>
<status status="PASS" start="2026-05-08T02:15:07.904401" elapsed="0.000651"/>
</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-05-08T02:05:00.757237" elapsed="607.147853"/>
</test>
<test id="s1-t3" name="Rerun Latency Test To Check Bug 6176" line="65">
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.906474" 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-05-08T02:15:07.906074" elapsed="0.000457"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.907753" 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-05-08T02:15:07.907414" elapsed="0.000381"/>
</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-05-08T02:15:07.908197" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-05-08T02:15:07.907945" elapsed="0.000314"/>
</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-05-08T02:15:07.911230" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-05-08T02:15:07.910966" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-05-08T02:15:07.910947" elapsed="0.000363"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-05-08T02:15:07.911628" 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-05-08T02:15:07.911744" 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-05-08T02:15:07.911441" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.912338" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.193 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.120" 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-05-08T02:15:07.911904" elapsed="0.000492"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-05-08T02:15:07.912956" 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-05-08T02:15:07.912536" elapsed="0.000448"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-05-08T02:15:07.914036" level="INFO">Length is 0.</msg>
<msg time="2026-05-08T02:15:07.914131" 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-05-08T02:15:07.913582" elapsed="0.000573"/>
</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-05-08T02:15:07.914314" elapsed="0.000324"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-05-08T02:15:07.915513" level="INFO">Logging into '10.30.171.120:22' as 'jenkins'.</msg>
<msg time="2026-05-08T02:15:08.503121" 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 Fri May  8 02:15:08 UTC 2026

  System load:  0.26               Processes:             106
  Usage of /:   19.6% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.120
  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: Fri May  8 02:05:01 2026 from 10.30.171.179
[?2004h[jenkins@releng-48317-713-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-05-08T02:15:07.915134" elapsed="0.588226"/>
</kw>
<msg time="2026-05-08T02:15:08.503463" 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-05-08T02:15:07.914791" elapsed="0.588767"/>
</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-05-08T02:15:07.913208" elapsed="0.590480"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-05-08T02:15:08.504378" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.193 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-05-08T02:25:14.579348" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-05-08T02:25:14.579887" level="INFO">${stdout} = </msg>
<msg time="2026-05-08T02:25:14.580021" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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-05-08T02:15:08.503962" elapsed="606.076117"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T02:25:14.580575" elapsed="0.001041"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.582872" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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.193. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:16:13.666 16  switches: flows:  107567 106822 105936 105514 105845 106126 105311 105903 104441 103437 104914 106941 102621 103144 104105 104055  total = 28.044700 per ms 
02:17:13.767 16  switches: flows:  115552 113311 112675 112551 112495 113834 113137 111478 109697 110426 110374 112964 110446 109580 113259 111674  total = 29.841030 per ms 
02:18:13.868 16  switches: flows:  117331 115657 114421 113073 114124 115848 116748 113891 112135 113329 114609 114453 112145 113227 113159 113049  total = 30.402554 per ms 
02:19:13.969 16  switches: flows:  119391 118184 118951 116978 119457 120489 119905 118902 116083 118688 117140 118762 117618 116714 116050 117305  total = 31.457725 per ms 
02:20:14.070 16  switches: flows:  121039 119719 119997 120444 118041 120990 121802 117993 118096 118397 118415 119264 118368 118786 118493 118956  total = 31.760339 per ms 
02:21:14.171 16  switches: flows:  123710 122679 122035 122451 121614 119829 122028 121715 118755 119460 119219 119572 120032 119360 120091 121130  total = 32.174234 per ms 
02:22:14.273 16  switches: flows:  122875 121849 124631 123073 121179 121497 123145 120537 119372 118836 119588 120258 118792 120748 118898 121344  total = 32.223147 per ms 
02:23:14.374 16  switches: flows:  123808 122837 123116 122653 119774 121824 123798 120234 119578 120929 118392 120090 119522 120183 119260 119796  total = 32.209447 per ms 
02:24:14.475 16  switches: flows:  123086 119571 121442 119113 117277 121015 120781 117532 116236 115840 116710 117260 117524 120629 115677 117384  total = 31.565251 per ms 
02:25:14.576 16  switches: flows:  122515 121956 121617 120215 117120 119287 121446 118665 117161 117358 116412 117124 117794 118263 116905 118223  total = 31.648149 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29841.03/32223.15/31475.76/10521.15 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:25:14.582006" elapsed="0.001280"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-05-08T02:25:14.583800" elapsed="0.000075"/>
</return>
<status status="PASS" start="2026-05-08T02:25:14.583481" elapsed="0.000480"/>
</branch>
<status status="PASS" start="2026-05-08T02:25:14.583427" elapsed="0.000596"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-05-08T02:25:14.584279" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-05-08T02:25:14.584186" elapsed="0.000191"/>
</branch>
<status status="NOT RUN" start="2026-05-08T02:25:14.584120" elapsed="0.000310"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-05-08T02:25:14.584518" elapsed="0.000034"/>
</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-05-08T02:25:14.590562" elapsed="0.000746"/>
</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-05-08T02:25:14.591636" elapsed="0.000340"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-05-08T02:25:14.592294" elapsed="0.000217"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-05-08T02:25:14.585270" elapsed="0.007357"/>
</kw>
<msg time="2026-05-08T02:25:14.592903" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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-05-08T02:15:07.908608" elapsed="606.684354"/>
</kw>
<status status="PASS" start="2026-05-08T02:15:07.908286" elapsed="606.684783"/>
</branch>
<status status="PASS" start="2026-05-08T02:15:07.907923" elapsed="606.685196"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.593987" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.193: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.193. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:16:13.666 16  switches: flows:  107567 106822 105936 105514 105845 106126 105311 105903 104441 103437 104914 106941 102621 103144 104105 104055  total = 28.044700 per ms 
02:17:13.767 16  switches: flows:  115552 113311 112675 112551 112495 113834 113137 111478 109697 110426 110374 112964 110446 109580 113259 111674  total = 29.841030 per ms 
02:18:13.868 16  switches: flows:  117331 115657 114421 113073 114124 115848 116748 113891 112135 113329 114609 114453 112145 113227 113159 113049  total = 30.402554 per ms 
02:19:13.969 16  switches: flows:  119391 118184 118951 116978 119457 120489 119905 118902 116083 118688 117140 118762 117618 116714 116050 117305  total = 31.457725 per ms 
02:20:14.070 16  switches: flows:  121039 119719 119997 120444 118041 120990 121802 117993 118096 118397 118415 119264 118368 118786 118493 118956  total = 31.760339 per ms 
02:21:14.171 16  switches: flows:  123710 122679 122035 122451 121614 119829 122028 121715 118755 119460 119219 119572 120032 119360 120091 121130  total = 32.174234 per ms 
02:22:14.273 16  switches: flows:  122875 121849 124631 123073 121179 121497 123145 120537 119372 118836 119588 120258 118792 120748 118898 121344  total = 32.223147 per ms 
02:23:14.374 16  switches: flows:  123808 122837 123116 122653 119774 121824 123798 120234 119578 120929 118392 120090 119522 120183 119260 119796  total = 32.209447 per ms 
02:24:14.475 16  switches: flows:  123086 119571 121442 119113 117277 121015 120781 117532 116236 115840 116710 117260 117524 120629 115677 117384  total = 31.565251 per ms 
02:25:14.576 16  switches: flows:  122515 121956 121617 120215 117120 119287 121446 118665 117161 117358 116412 117124 117794 118263 116905 118223  total = 31.648149 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29841.03/32223.15/31475.76/10521.15 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:25:14.593512" elapsed="0.000547"/>
</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-05-08T02:25:14.594221" elapsed="0.000368"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-05-08T02:25:14.594968" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-05-08T02:25:14.595056" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 29841.03/32223.15/31475.76/10521.15 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-05-08T02:25:14.594750" elapsed="0.000330"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:25:14.595500" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 29841.03/32223.15/31475.76/10521.15 | 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-05-08T02:25:14.595248" elapsed="0.000279"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.597915" 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-05-08T02:25:14.595671" elapsed="0.002300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.600502" level="INFO">29841.03/32223.15/31475.76/10521.15</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-05-08T02:25:14.598116" elapsed="0.002442"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:25:14.603389" 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-05-08T02:25:14.600708" elapsed="0.002711"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-05-08T02:25:14.606404" level="INFO">@{result_value_list} = [ 29841.03 | 32223.15 | 31475.76 | 10521.15 ]</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-05-08T02:25:14.603654" elapsed="0.002791"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.607007" level="INFO">Length is 4.</msg>
<msg time="2026-05-08T02:25:14.607109" 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-05-08T02:25:14.606638" elapsed="0.000512"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.612399" level="INFO">min :: 29841.03</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-05-08T02:25:14.607624" elapsed="0.004831"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-05-08T02:25:14.607470" elapsed="0.005021"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.616983" level="INFO">max :: 32223.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-05-08T02:25:14.612704" elapsed="0.004335"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-05-08T02:25:14.612578" elapsed="0.004495"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.622756" level="INFO">avg :: 31475.76</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-05-08T02:25:14.617322" elapsed="0.005491"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-05-08T02:25:14.617186" elapsed="0.005661"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.627336" level="INFO">stdev :: 10521.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-05-08T02:25:14.623059" elapsed="0.004331"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-05-08T02:25:14.622932" elapsed="0.004492"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-05-08T02:25:14.607251" elapsed="0.020203"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.631353" level="INFO">${min} = 29841.03</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-05-08T02:25:14.627614" elapsed="0.003766"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.635199" level="INFO">${max} = 32223.15</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-05-08T02:25:14.631534" elapsed="0.003692"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.639098" level="INFO">${average} = 31475.76</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-05-08T02:25:14.635378" elapsed="0.003746"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.642969" level="INFO">${stdev} = 10521.15</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-05-08T02:25:14.639304" elapsed="0.003692"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.643517" level="INFO">${date} = 2026-05-08 02:25:14</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-05-08T02:25:14.643156" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.644096" level="INFO">CBench Result: 2026-05-08 02:25:14,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,29841.03,32223.15,31475.76,10521.15</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-05-08T02:25:14.643693" elapsed="0.000458"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-05-08T02:25:14.645247" 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-05-08T02:25:14.644771" elapsed="0.000544"/>
</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-05-08T02:25:14.645481" elapsed="0.000454"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-05-08T02:25:14.644305" elapsed="0.001694"/>
</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-05-08T02:15:07.906845" elapsed="606.739212"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.646535" 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-05-08T02:25:14.646220" elapsed="0.000370"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-05-08T02:25:14.647883" 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-05-08T02:25:14.647393" elapsed="0.000517"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-05-08T02:25:14.648131" elapsed="0.000046"/>
</return>
<status status="PASS" start="2026-05-08T02:25:14.647985" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-05-08T02:25:14.647966" elapsed="0.000269"/>
</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-05-08T02:25:14.648377" 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-05-08T02:25:14.648538" elapsed="0.000020"/>
</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-05-08T02:25:14.648697" elapsed="0.000020"/>
</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-05-08T02:25:14.648887" 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-05-08T02:25:14.649037" elapsed="0.000020"/>
</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-05-08T02:25:14.649197" 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-05-08T02:25:14.649373" elapsed="0.000023"/>
</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-05-08T02:25:14.649607" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-05-08T02:25:14.649462" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-05-08T02:25:14.649445" elapsed="0.000238"/>
</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-05-08T02:25:14.646977" elapsed="0.002757"/>
</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-05-08T02:15:07.905529" elapsed="606.744252"/>
</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-05-08T01:54:51.837728" elapsed="1822.812670"/>
</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>
