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

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-02T01:57:28.379797" elapsed="0.711247"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-02T01:57:29.140440" level="INFO">@root&gt;log:set ERROR</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-02T01:57:29.091268" elapsed="0.049240"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-02T01:57:29.142201" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-02T01:57:29.142309" level="INFO">${output} = [?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-02T01:57:29.140678" elapsed="0.001660"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-02T01:57:29.142496" elapsed="0.000210"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T01:57:29.142870" elapsed="0.000199"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T01:57:29.143557" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T01:57:29.143241" elapsed="0.000371"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-02T01:57:29.143663" elapsed="0.000050"/>
</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.132
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-02T01:57:28.378338" elapsed="0.765491"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>KarafKeywords.Issue Command On Karaf Console</arg>
<arg>log:set ${log_level}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-04-02T01:57:28.374653" elapsed="0.769240"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-02T01:57:29.144418" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv&lt;/a&gt;'.</msg>
<arg>${latency_results_file}</arg>
<arg>LATENCY_MIN,LATENCY_MAX,LATENCY_AVERAGE\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-02T01:57:29.144082" elapsed="0.000393"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-02T01:57:29.144872" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv&lt;/a&gt;'.</msg>
<arg>${throughput_results_file}</arg>
<arg>THROUGHPUT_MIN,THROUGHPUT_MAX,THROUGHPUT_AVERAGE\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-02T01:57:29.144629" elapsed="0.000300"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-02T01:57:29.145528" level="INFO">${duration_in_ms} = 60000</msg>
<var>${duration_in_ms}</var>
<arg>${duration_in_secs} * 1000</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-02T01:57:29.145094" elapsed="0.000462"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-02T01:57:29.146059" level="INFO">${duration_in_ms} = 60000</msg>
<arg>${duration_in_ms}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-02T01:57:29.145728" elapsed="0.000374"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-02T01:57:29.146648" level="INFO">${test_timeout} = 900.0</msg>
<var>${test_timeout}</var>
<arg>(${loops} * ${duration_in_secs}) * 1.5</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-02T01:57:29.146271" elapsed="0.000404"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-02T01:57:29.147162" level="INFO">${test_timeout} = 900.0</msg>
<arg>${test_timeout}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-02T01:57:29.146836" elapsed="0.000369"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="File Should Exist" owner="OperatingSystem">
<arg>${cbench_executable}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="NOT RUN" start="2026-04-02T01:57:29.147533" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-04-02T01:57:29.147288" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Verify File Exists On Remote System" owner="Utils">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-02T01:57:29.152176" level="INFO">${conn_id} = 2</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T01:57:29.151755" elapsed="0.000449"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-02T01:57:29.153232" level="INFO">Length is 0.</msg>
<msg time="2026-04-02T01:57:29.153316" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-02T01:57:29.152757" elapsed="0.000584"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T01:57:29.153497" elapsed="0.000346"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-02T01:57:29.154858" level="INFO">Logging into '10.30.171.26:22' as 'jenkins'.</msg>
<msg time="2026-04-02T01:57:29.902105" 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 Thu Apr  2 01:57:29 UTC 2026

  System load:  0.13               Processes:             110
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.26
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


[?2004h[jenkins@releng-48317-677-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-02T01:57:29.154368" elapsed="0.747900"/>
</kw>
<msg time="2026-04-02T01:57:29.902358" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T01:57:29.154000" elapsed="0.748448"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-02T01:57:29.152412" elapsed="0.750153"/>
</kw>
<kw name="File Should Exist" owner="SSHLibrary">
<msg time="2026-04-02T01:57:29.909708" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<arg>${file}</arg>
<doc>Fails if the given ``path`` does NOT point to an existing file.</doc>
<status status="PASS" start="2026-04-02T01:57:29.902779" elapsed="0.008799"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T01:57:29.911870" elapsed="0.000624"/>
</kw>
<arg>${cbench_system}</arg>
<arg>${cbench_executable}</arg>
<doc>Will create connection with public key and will PASS if the given ${file} exists,
otherwise will FAIL</doc>
<status status="PASS" start="2026-04-02T01:57:29.151223" elapsed="0.761409"/>
</kw>
<status status="PASS" start="2026-04-02T01:57:29.147891" elapsed="0.764825"/>
</branch>
<status status="PASS" start="2026-04-02T01:57:29.147263" elapsed="0.765519"/>
</if>
<kw name="Should Be True" owner="BuiltIn">
<arg>${loops} &gt;= 2</arg>
<arg>If number of loops is less than 2, cbench will not run</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-02T01:57:29.913148" elapsed="0.001044"/>
</kw>
<kw name="Verify_Feature_Is_Installed" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-02T01:57:29.923992" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-04-02T01:57:29.923865" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-04-02T01:57:29.923837" elapsed="0.000234"/>
</if>
<kw name="Issue_Command_On_Karaf_Console" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-02T01:57:29.927721" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-04-02T01:57:29.927607" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-04-02T01:57:29.927586" elapsed="0.000205"/>
</if>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${controller}</arg>
<arg>port=${karaf_port}</arg>
<arg>prompt=${KARAF_PROMPT_LOGIN}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T01:57:29.927928" elapsed="0.000464"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-02T01:57:29.928811" level="INFO">Logging into '10.30.171.132:8101' as 'karaf'.</msg>
<msg time="2026-04-02T01:57:30.123501" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-02T01:57:29.928543" elapsed="0.195045"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.216283" level="INFO">@root&gt;feature:list -i | 0[C 0g[Krep odl-openflowplugin-drop-test</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-02T01:57:30.123760" elapsed="0.092710"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.222370" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                                    x OpenDaylight :: Openflow Plugin :: Drop Test
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-02T01:57:30.222584" level="INFO">${output} = [?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                     ...</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-02T01:57:30.216792" elapsed="0.005824"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-02T01:57:30.222767" elapsed="0.000292"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T01:57:30.223234" elapsed="0.000236"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T01:57:30.223969" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                                    x OpenDaylight :: Openflow Plugin :: Drop Test
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T01:57:30.223618" elapsed="0.000420"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-02T01:57:30.224093" elapsed="0.000129"/>
</return>
<msg time="2026-04-02T01:57:30.224401" 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.132
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-02T01:57:29.927244" elapsed="0.297192"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>${feature_name}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-02T01:57:30.224592" elapsed="0.000582"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-02T01:57:30.225227" elapsed="0.000033"/>
</return>
<arg>odl-openflowplugin-drop-test</arg>
<doc>Will Succeed if the given ${feature_name} is found in the output of "feature:list -i"</doc>
<status status="PASS" start="2026-04-02T01:57:29.923234" elapsed="0.302128"/>
</kw>
<kw name="Issue_Command_On_Karaf_Console" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-02T01:57:30.229387" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-04-02T01:57:30.229239" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-04-02T01:57:30.229212" elapsed="0.000256"/>
</if>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${controller}</arg>
<arg>port=${karaf_port}</arg>
<arg>prompt=${KARAF_PROMPT_LOGIN}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T01:57:30.229608" elapsed="0.000491"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.230554" level="INFO">Logging into '10.30.171.132:8101' as 'karaf'.</msg>
<msg time="2026-04-02T01:57:30.406416" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-02T01:57:30.230276" elapsed="0.176262"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.431110" level="INFO">@root&gt;dropallpacketsrpc on</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-02T01:57:30.406747" elapsed="0.024446"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.433444" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-02T01:57:30.433553" level="INFO">${output} = [?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-02T01:57:30.431351" elapsed="0.002233"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-02T01:57:30.433732" elapsed="0.000195"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T01:57:30.434080" elapsed="0.000216"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T01:57:30.434757" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T01:57:30.434444" elapsed="0.000363"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-02T01:57:30.434892" elapsed="0.000052"/>
</return>
<arg>dropallpacketsrpc on</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.171.132
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-02T01:57:30.228855" elapsed="0.206210"/>
</kw>
<status status="PASS" start="2026-04-02T01:57:28.372878" elapsed="2.062275"/>
</kw>
<test id="s1-t1" name="Cbench Latency Test" line="37">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T01:57:30.437511" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T01:57:30.436301" elapsed="0.001280"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-02T01:57:30.439109" level="INFO">${output_filename} = latency.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-02T01:57:30.438731" elapsed="0.000447"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-02T01:57:30.439521" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-04-02T01:57:30.439261" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-02T01:57:30.442633" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-04-02T01:57:30.442368" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-04-02T01:57:30.442347" elapsed="0.000374"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.443086" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-02T01:57:30.442875" elapsed="0.000382"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T01:57:30.443835" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.132 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.26" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T01:57:30.443398" elapsed="0.000498"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.444562" level="INFO">${conn_id} = 5</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T01:57:30.444040" elapsed="0.000550"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-02T01:57:30.445543" level="INFO">Length is 0.</msg>
<msg time="2026-04-02T01:57:30.445636" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-02T01:57:30.445196" elapsed="0.000464"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T01:57:30.445810" elapsed="0.000359"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.447097" level="INFO">Logging into '10.30.171.26:22' as 'jenkins'.</msg>
<msg time="2026-04-02T01:57:30.804928" 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 Thu Apr  2 01:57:29 UTC 2026

  System load:  0.13               Processes:             110
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.26
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Thu Apr  2 01:57:29 2026 from 10.30.170.227
[?2004h[jenkins@releng-48317-677-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-02T01:57:30.446699" elapsed="0.358379"/>
</kw>
<msg time="2026-04-02T01:57:30.805171" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T01:57:30.446327" elapsed="0.358924"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-02T01:57:30.444798" elapsed="0.360563"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-02T01:57:30.806082" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.132 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-02T02:07:36.935332" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-02T02:07:36.935872" level="INFO">${stdout} = </msg>
<msg time="2026-04-02T02:07:36.935981" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-02T01:57:30.805562" elapsed="606.130480"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T02:07:36.936544" elapsed="0.001391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.939156" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132: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.132. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:58:36.024 16  switches: flows:  111176 108449 105712 109032 108962 107391 109892 106236 105372 108608 107514 103875 104241 104924 103259 106278  total = 28.515350 per ms 
01:59:36.125 16  switches: flows:  124749 119828 118990 123875 122166 119794 122348 120880 118399 120013 121414 117762 116711 118757 114798 119258  total = 31.942381 per ms 
02:00:36.226 16  switches: flows:  124068 120207 118293 125226 120968 119731 122916 120599 117437 120388 121182 118144 115774 118404 115506 120516  total = 31.936017 per ms 
02:01:36.329 16  switches: flows:  122954 119133 117660 123008 120536 117910 120875 117306 117478 118510 120863 116093 115549 117612 114405 118594  total = 31.587657 per ms 
02:02:36.430 16  switches: flows:  124570 121155 119285 124225 122780 121308 122078 121487 119193 120908 121759 118635 118396 119223 116239 121626  total = 32.160759 per ms 
02:03:36.530 16  switches: flows:  125326 121374 119858 126294 122215 120774 121961 121254 119501 121596 122839 119016 117963 118305 117218 120535  total = 32.213355 per ms 
02:04:36.631 16  switches: flows:  124959 120432 119668 123535 122502 120340 122781 119886 120651 120412 121618 118903 119471 119144 118780 121035  total = 32.181572 per ms 
02:05:36.731 16  switches: flows:  122606 117977 118435 119505 117555 118141 117989 120422 116135 118589 119620 117121 116719 117464 112892 117709  total = 31.428822 per ms 
02:06:36.831 16  switches: flows:  121057 118786 116390 120013 117626 116475 117799 117904 115140 114403 116443 114253 115934 113702 114322 112526  total = 30.994450 per ms 
02:07:36.932 16  switches: flows:  126587 124216 121920 124199 122961 120986 122181 124883 120185 119397 121369 117771 119753 120092 119178 119189  total = 32.360300 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 30994.45/32360.30/31867.26/10630.73 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.938345" elapsed="0.001104"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-02T02:07:36.939951" elapsed="0.000074"/>
</return>
<status status="PASS" start="2026-04-02T02:07:36.939645" elapsed="0.000461"/>
</branch>
<status status="PASS" start="2026-04-02T02:07:36.939585" elapsed="0.000617"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-02T02:07:36.940423" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-04-02T02:07:36.940338" elapsed="0.000179"/>
</branch>
<status status="NOT RUN" start="2026-04-02T02:07:36.940302" elapsed="0.000264"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-02T02:07:36.940641" elapsed="0.000030"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T02:07:36.944736" elapsed="0.000518"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T02:07:36.945463" elapsed="0.000237"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T02:07:36.945885" elapsed="0.000146"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-02T02:07:36.941419" elapsed="0.004686"/>
</kw>
<msg time="2026-04-02T02:07:36.946313" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-02T01:57:30.439945" elapsed="606.506406"/>
</kw>
<status status="PASS" start="2026-04-02T01:57:30.439610" elapsed="606.506810"/>
</branch>
<status status="PASS" start="2026-04-02T01:57:30.439237" elapsed="606.507216"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.947068" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132: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.132. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:58:36.024 16  switches: flows:  111176 108449 105712 109032 108962 107391 109892 106236 105372 108608 107514 103875 104241 104924 103259 106278  total = 28.515350 per ms 
01:59:36.125 16  switches: flows:  124749 119828 118990 123875 122166 119794 122348 120880 118399 120013 121414 117762 116711 118757 114798 119258  total = 31.942381 per ms 
02:00:36.226 16  switches: flows:  124068 120207 118293 125226 120968 119731 122916 120599 117437 120388 121182 118144 115774 118404 115506 120516  total = 31.936017 per ms 
02:01:36.329 16  switches: flows:  122954 119133 117660 123008 120536 117910 120875 117306 117478 118510 120863 116093 115549 117612 114405 118594  total = 31.587657 per ms 
02:02:36.430 16  switches: flows:  124570 121155 119285 124225 122780 121308 122078 121487 119193 120908 121759 118635 118396 119223 116239 121626  total = 32.160759 per ms 
02:03:36.530 16  switches: flows:  125326 121374 119858 126294 122215 120774 121961 121254 119501 121596 122839 119016 117963 118305 117218 120535  total = 32.213355 per ms 
02:04:36.631 16  switches: flows:  124959 120432 119668 123535 122502 120340 122781 119886 120651 120412 121618 118903 119471 119144 118780 121035  total = 32.181572 per ms 
02:05:36.731 16  switches: flows:  122606 117977 118435 119505 117555 118141 117989 120422 116135 118589 119620 117121 116719 117464 112892 117709  total = 31.428822 per ms 
02:06:36.831 16  switches: flows:  121057 118786 116390 120013 117626 116475 117799 117904 115140 114403 116443 114253 115934 113702 114322 112526  total = 30.994450 per ms 
02:07:36.932 16  switches: flows:  126587 124216 121920 124199 122961 120986 122181 124883 120185 119397 121369 117771 119753 120092 119178 119189  total = 32.360300 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 30994.45/32360.30/31867.26/10630.73 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.946658" elapsed="0.000544"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-02T02:07:36.947416" elapsed="0.000502"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-02T02:07:36.948533" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-02T02:07:36.948660" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 30994.45/32360.30/31867.26/10630.73 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-02T02:07:36.948207" elapsed="0.000488"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:07:36.949356" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 30994.45/32360.30/31867.26/10630.73 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:07:36.948912" elapsed="0.000483"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.951986" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.949600" elapsed="0.002443"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.954512" level="INFO">30994.45/32360.30/31867.26/10630.73</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.952208" elapsed="0.002371"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:07:36.956951" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:07:36.954733" elapsed="0.002248"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:07:36.959480" level="INFO">@{result_value_list} = [ 30994.45 | 32360.30 | 31867.26 | 10630.73 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:07:36.957239" elapsed="0.002268"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.959988" level="INFO">Length is 4.</msg>
<msg time="2026-04-02T02:07:36.960076" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-02T02:07:36.959663" elapsed="0.000437"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.964868" level="INFO">min :: 30994.45</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.960530" elapsed="0.004395"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-02T02:07:36.960395" elapsed="0.004565"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.969538" level="INFO">max :: 32360.30</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.965224" elapsed="0.004371"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-02T02:07:36.965055" elapsed="0.004575"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.974226" level="INFO">avg :: 31867.26</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.969852" elapsed="0.004437"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-02T02:07:36.969721" elapsed="0.004605"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.979079" level="INFO">stdev :: 10630.73</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.974561" elapsed="0.004645"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-02T02:07:36.974424" elapsed="0.004835"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-02T02:07:36.960192" elapsed="0.019104"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.983287" level="INFO">${min} = 30994.45</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:07:36.979477" elapsed="0.003839"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.987481" level="INFO">${max} = 32360.30</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:07:36.983479" elapsed="0.004031"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.991731" level="INFO">${average} = 31867.26</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:07:36.987678" elapsed="0.004081"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.995729" level="INFO">${stdev} = 10630.73</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:07:36.991922" elapsed="0.003835"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.996313" level="INFO">${date} = 2026-04-02 02:07:36</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-02T02:07:36.995928" elapsed="0.000411"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.996919" level="INFO">CBench Result: 2026-04-02 02:07:36,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,30994.45,32360.30,31867.26,10630.73</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:36.996488" elapsed="0.000490"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-02T02:07:36.998186" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-02T02:07:36.997709" elapsed="0.000546"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-02T02:07:36.998409" 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-04-02T02:07:36.997169" elapsed="0.001783"/>
</kw>
<arg>-m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${latency_threshold}</arg>
<arg>${latency_results_file}</arg>
<status status="PASS" start="2026-04-02T01:57:30.438043" elapsed="606.560973"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-02T02:07:36.999510" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-02T02:07:36.999187" elapsed="0.000378"/>
</kw>
<kw name="Log Results As Zero If Cbench Timed Out" type="TEARDOWN">
<kw name="Run Keyword If Timeout Occurred" owner="BuiltIn">
<arg>Log Results And Determine Status</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>${output_filename}</arg>
<doc>Runs the given keyword if either a test or a keyword timeout has occurred.</doc>
<status status="PASS" start="2026-04-02T02:07:37.000098" elapsed="0.000290"/>
</kw>
<status status="PASS" start="2026-04-02T02:07:36.999788" elapsed="0.000672"/>
</kw>
<doc>cbench executed in default latency mode. Test parameters have defaults, but can be overridden
on the pybot command line</doc>
<tag>cbench</tag>
<tag>latency</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-02T01:57:30.435334" elapsed="606.565164"/>
</test>
<test id="s1-t2" name="Cbench Throughput Test" line="51">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:37.002091" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:37.001703" elapsed="0.000465"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-02T02:07:37.003438" level="INFO">${output_filename} = throughput.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-02T02:07:37.003085" elapsed="0.000396"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-02T02:07:37.003854" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-04-02T02:07:37.003622" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-02T02:07:37.006984" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-02T02:07:37.006729" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-04-02T02:07:37.006709" elapsed="0.000356"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-02T02:07:37.007445" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-02T02:07:37.007222" elapsed="0.000377"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:07:37.008181" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.132 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.26" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:07:37.007734" elapsed="0.000507"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-02T02:07:37.008781" level="INFO">${conn_id} = 7</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T02:07:37.008382" elapsed="0.000425"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-02T02:07:37.009752" level="INFO">Length is 0.</msg>
<msg time="2026-04-02T02:07:37.009841" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-02T02:07:37.009410" 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-04-02T02:07:37.010009" elapsed="0.000353"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-02T02:07:37.011263" level="INFO">Logging into '10.30.171.26:22' as 'jenkins'.</msg>
<msg time="2026-04-02T02:07:37.657923" 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 Thu Apr  2 02:07:37 UTC 2026

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


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Thu Apr  2 01:57:30 2026 from 10.30.170.227
[?2004h[jenkins@releng-48317-677-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-02T02:07:37.010883" elapsed="0.647281"/>
</kw>
<msg time="2026-04-02T02:07:37.658259" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T02:07:37.010515" elapsed="0.647835"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-02T02:07:37.009010" elapsed="0.649458"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-02T02:07:37.659021" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.132 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-02T02:17:43.866414" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-02T02:17:43.866808" level="INFO">${stdout} = </msg>
<msg time="2026-04-02T02:17:43.866876" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.132:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-02T02:07:37.658698" elapsed="606.208216"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T02:17:43.867272" elapsed="0.000509"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.868575" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.132: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.132. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:08:42.791 16  switches: flows:  510442 507293 503792 510159 502750 497701 504434 505920 487583 488219 476972 481390 486089 472014 488546 509980  total = 132.221400 per ms 
02:09:42.892 16  switches: flows:  542655 534587 523248 538115 528238 528792 534003 540439 526378 529593 540515 535981 532008 526533 534928 542271  total = 142.064970 per ms 
02:10:42.995 16  switches: flows:  549632 562280 558357 557062 557570 558955 554002 565008 556739 560301 559594 562453 556120 560096 561112 563284  total = 148.791169 per ms 
02:11:43.095 16  switches: flows:  559853 565915 557464 563859 555170 558557 557178 566794 557802 563029 563447 561042 554944 561753 565814 559853  total = 149.290371 per ms 
02:12:43.343 16  switches: flows:  546026 544836 548532 552904 549550 549862 549022 551866 550310 548498 547519 551070 549144 550871 548115 545562  total = 145.792771 per ms 
02:13:43.446 16  switches: flows:  524179 532063 532141 529401 542931 532024 491538 547337 529207 530479 523099 527480 523067 527337 499876 529746  total = 140.128162 per ms 
02:14:43.548 16  switches: flows:  580620 582697 573584 574260 578052 580250 578951 580218 574148 581092 576823 577253 576994 575755 584555 578952  total = 153.975058 per ms 
02:15:43.650 16  switches: flows:  561902 571796 568502 565347 559581 569065 571951 569418 566931 554624 563735 566676 572894 561906 564798 573891  total = 150.797805 per ms 
02:16:43.752 16  switches: flows:  537326 545850 546874 544789 510070 546889 549693 548041 556992 507321 555683 560245 553957 557572 542869 515173  total = 144.412898 per ms 
02:17:43.853 16  switches: flows:  546590 543381 551340 545444 544623 555104 540384 546872 535067 543924 542753 549929 539138 538174 552074 546702  total = 145.114626 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 140128.16/153975.06/146707.54/49077.20 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.868018" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-02T02:17:43.869171" elapsed="0.000057"/>
</return>
<status status="PASS" start="2026-04-02T02:17:43.868921" elapsed="0.000360"/>
</branch>
<status status="PASS" start="2026-04-02T02:17:43.868878" elapsed="0.000437"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-02T02:17:43.869448" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-04-02T02:17:43.869396" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-04-02T02:17:43.869374" elapsed="0.000161"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-02T02:17:43.869578" elapsed="0.000019"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T02:17:43.873317" elapsed="0.000517"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T02:17:43.874083" elapsed="0.000261"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T02:17:43.874530" elapsed="0.000143"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-02T02:17:43.870032" elapsed="0.004716"/>
</kw>
<msg time="2026-04-02T02:17:43.874943" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.132:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-02T02:07:37.004281" elapsed="606.870724"/>
</kw>
<status status="PASS" start="2026-04-02T02:07:37.003940" elapsed="606.871223"/>
</branch>
<status status="PASS" start="2026-04-02T02:07:37.003598" elapsed="606.871608"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.875858" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.132: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.132. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:08:42.791 16  switches: flows:  510442 507293 503792 510159 502750 497701 504434 505920 487583 488219 476972 481390 486089 472014 488546 509980  total = 132.221400 per ms 
02:09:42.892 16  switches: flows:  542655 534587 523248 538115 528238 528792 534003 540439 526378 529593 540515 535981 532008 526533 534928 542271  total = 142.064970 per ms 
02:10:42.995 16  switches: flows:  549632 562280 558357 557062 557570 558955 554002 565008 556739 560301 559594 562453 556120 560096 561112 563284  total = 148.791169 per ms 
02:11:43.095 16  switches: flows:  559853 565915 557464 563859 555170 558557 557178 566794 557802 563029 563447 561042 554944 561753 565814 559853  total = 149.290371 per ms 
02:12:43.343 16  switches: flows:  546026 544836 548532 552904 549550 549862 549022 551866 550310 548498 547519 551070 549144 550871 548115 545562  total = 145.792771 per ms 
02:13:43.446 16  switches: flows:  524179 532063 532141 529401 542931 532024 491538 547337 529207 530479 523099 527480 523067 527337 499876 529746  total = 140.128162 per ms 
02:14:43.548 16  switches: flows:  580620 582697 573584 574260 578052 580250 578951 580218 574148 581092 576823 577253 576994 575755 584555 578952  total = 153.975058 per ms 
02:15:43.650 16  switches: flows:  561902 571796 568502 565347 559581 569065 571951 569418 566931 554624 563735 566676 572894 561906 564798 573891  total = 150.797805 per ms 
02:16:43.752 16  switches: flows:  537326 545850 546874 544789 510070 546889 549693 548041 556992 507321 555683 560245 553957 557572 542869 515173  total = 144.412898 per ms 
02:17:43.853 16  switches: flows:  546590 543381 551340 545444 544623 555104 540384 546872 535067 543924 542753 549929 539138 538174 552074 546702  total = 145.114626 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 140128.16/153975.06/146707.54/49077.20 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.875445" elapsed="0.000517"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-02T02:17:43.876247" elapsed="0.000512"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-02T02:17:43.877321" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-02T02:17:43.877450" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 140128.16/153975.06/146707.54/49077.20 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-02T02:17:43.876987" elapsed="0.000498"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:17:43.878115" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 140128.16/153975.06/146707.54/49077.20 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:17:43.877700" elapsed="0.000477"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.881604" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.878387" elapsed="0.003296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.885140" level="INFO">140128.16/153975.06/146707.54/49077.20</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.881891" elapsed="0.003332"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:17:43.888466" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:17:43.885435" elapsed="0.003059"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:17:43.890928" level="INFO">@{result_value_list} = [ 140128.16 | 153975.06 | 146707.54 | 49077.20 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:17:43.888682" elapsed="0.002274"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.891456" level="INFO">Length is 4.</msg>
<msg time="2026-04-02T02:17:43.891543" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-02T02:17:43.891147" elapsed="0.000420"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.896308" level="INFO">min :: 140128.16</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.891955" elapsed="0.004419"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-02T02:17:43.891824" elapsed="0.004585"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.901147" level="INFO">max :: 153975.06</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.896637" elapsed="0.004580"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-02T02:17:43.896506" elapsed="0.004748"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.905808" level="INFO">avg :: 146707.54</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.901477" elapsed="0.004387"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-02T02:17:43.901346" elapsed="0.004553"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.910672" level="INFO">stdev :: 49077.20</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.906135" elapsed="0.004593"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-02T02:17:43.905987" elapsed="0.004777"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-02T02:17:43.891636" elapsed="0.019159"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.914791" level="INFO">${min} = 140128.16</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:17:43.910956" elapsed="0.003862"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.918895" level="INFO">${max} = 153975.06</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:17:43.914974" elapsed="0.003948"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.922876" level="INFO">${average} = 146707.54</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:17:43.919075" elapsed="0.003828"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.926943" level="INFO">${stdev} = 49077.20</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:17:43.923056" elapsed="0.003915"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.927507" level="INFO">${date} = 2026-04-02 02:17:43</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-02T02:17:43.927153" elapsed="0.000380"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.928089" level="INFO">CBench Result: 2026-04-02 02:17:43,-t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,140128.16,153975.06,146707.54,49077.20</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.927681" elapsed="0.000484"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-02T02:17:43.929198" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-02T02:17:43.928786" elapsed="0.000479"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-02T02:17:43.929416" elapsed="0.000453"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-02T02:17:43.928316" elapsed="0.001630"/>
</kw>
<arg>-t -m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${throughput_threshold}</arg>
<arg>${throughput_results_file}</arg>
<status status="PASS" start="2026-04-02T02:07:37.002501" elapsed="606.927506"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.930553" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-02T02:17:43.930216" elapsed="0.000395"/>
</kw>
<kw name="Log Results As Zero If Cbench Timed Out" type="TEARDOWN">
<kw name="Run Keyword If Timeout Occurred" owner="BuiltIn">
<arg>Log Results And Determine Status</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>${output_filename}</arg>
<doc>Runs the given keyword if either a test or a keyword timeout has occurred.</doc>
<status status="PASS" start="2026-04-02T02:17:43.931137" elapsed="0.000262"/>
</kw>
<status status="PASS" start="2026-04-02T02:17:43.930822" elapsed="0.000648"/>
</kw>
<doc>cbench executed in throughput mode (-t). Test parameters have defaults, but can be overridden
on the pybot command line</doc>
<tag>cbench</tag>
<tag>throughput</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-02T02:07:37.000972" elapsed="606.930537"/>
</test>
<test id="s1-t3" name="Rerun Latency Test To Check Bug 6176" line="65">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.932886" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.932504" elapsed="0.000438"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.934207" level="INFO">${output_filename} = bug.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-02T02:17:43.933847" elapsed="0.000403"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-02T02:17:43.934575" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-02T02:17:43.934356" elapsed="0.000277"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-02T02:17:43.937582" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-02T02:17:43.937333" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-04-02T02:17:43.937312" elapsed="0.000349"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-02T02:17:43.937988" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-02T02:17:43.937802" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.938719" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.132 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.26" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:17:43.938300" elapsed="0.000477"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-02T02:17:43.939342" level="INFO">${conn_id} = 9</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T02:17:43.938917" elapsed="0.000452"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-02T02:17:43.940412" level="INFO">Length is 0.</msg>
<msg time="2026-04-02T02:17:43.940506" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-02T02:17:43.939951" elapsed="0.000580"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T02:17:43.940674" elapsed="0.000322"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-02T02:17:43.941884" level="INFO">Logging into '10.30.171.26:22' as 'jenkins'.</msg>
<msg time="2026-04-02T02:17:44.536587" 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 Thu Apr  2 02:17:44 UTC 2026

  System load:  0.35               Processes:             103
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.26
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Thu Apr  2 02:07:37 2026 from 10.30.170.227
[?2004h[jenkins@releng-48317-677-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-02T02:17:43.941519" elapsed="0.595198"/>
</kw>
<msg time="2026-04-02T02:17:44.536787" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T02:17:43.941165" elapsed="0.595690"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-02T02:17:43.939573" elapsed="0.597382"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-02T02:17:44.537417" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.132 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-02T02:27:50.599251" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-02T02:27:50.599757" level="INFO">${stdout} = </msg>
<msg time="2026-04-02T02:27:50.599865" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-02T02:17:44.537148" elapsed="606.062776"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T02:27:50.600421" elapsed="0.000691"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.602385" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132: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.132. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:18:49.695 16  switches: flows:  104485 105321 103833 104593 102903 104993 102594 103754 102182 102921 101110 102480 99345 100970 100135 100265  total = 27.364733 per ms 
02:19:49.796 16  switches: flows:  116205 118670 117230 115640 114963 116044 116008 115348 114214 113308 111529 115456 114154 111942 112884 111744  total = 30.538008 per ms 
02:20:49.896 16  switches: flows:  123158 125195 123619 119653 120535 122795 120971 122913 119631 118928 117230 119713 118950 118085 119299 117213  total = 32.077944 per ms 
02:21:49.996 16  switches: flows:  117522 119346 117547 115827 115490 118123 116436 116881 113850 115100 112769 113841 113729 114031 114459 112835  total = 30.745126 per ms 
02:22:50.096 16  switches: flows:  114262 115328 113717 112513 112706 114701 113731 113419 111782 110545 110321 111318 111338 110321 110294 108953  total = 29.870962 per ms 
02:23:50.197 16  switches: flows:  119347 119628 122253 116870 118348 119994 120739 120127 119160 116579 115434 117687 118319 114580 115694 114838  total = 31.440695 per ms 
02:24:50.297 16  switches: flows:  120065 119636 122018 119679 117875 120938 121407 119696 120494 117482 115277 118717 118854 113882 116118 116464  total = 31.590626 per ms 
02:25:50.397 16  switches: flows:  118720 119377 120803 116570 118186 120233 119426 118022 118275 115852 113580 116370 118239 112238 114299 114555  total = 31.193648 per ms 
02:26:50.498 16  switches: flows:  122400 121554 123995 120572 119749 123145 122276 121428 120354 119678 117321 119714 120276 116195 117167 118576  total = 32.019696 per ms 
02:27:50.598 16  switches: flows:  122917 123633 124653 121263 119409 124093 122800 120133 120852 119737 117618 121070 120594 116591 117636 119412  total = 32.153148 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29870.96/32153.15/31292.21/10456.78 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.601525" elapsed="0.001062"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-02T02:27:50.602912" elapsed="0.000050"/>
</return>
<status status="PASS" start="2026-04-02T02:27:50.602706" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-04-02T02:27:50.602672" elapsed="0.000377"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-02T02:27:50.603210" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-04-02T02:27:50.603154" elapsed="0.000114"/>
</branch>
<status status="NOT RUN" start="2026-04-02T02:27:50.603108" elapsed="0.000193"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-02T02:27:50.603357" elapsed="0.000020"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-02T02:27:50.607007" elapsed="0.000509"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-02T02:27:50.607725" elapsed="0.000230"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-02T02:27:50.608167" elapsed="0.000142"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-02T02:27:50.603797" elapsed="0.004587"/>
</kw>
<msg time="2026-04-02T02:27:50.608580" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 10...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-02T02:17:43.934980" elapsed="606.673638"/>
</kw>
<status status="PASS" start="2026-04-02T02:17:43.934657" elapsed="606.674030"/>
</branch>
<status status="PASS" start="2026-04-02T02:17:43.934335" elapsed="606.674384"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.609348" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.132: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.132. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:18:49.695 16  switches: flows:  104485 105321 103833 104593 102903 104993 102594 103754 102182 102921 101110 102480 99345 100970 100135 100265  total = 27.364733 per ms 
02:19:49.796 16  switches: flows:  116205 118670 117230 115640 114963 116044 116008 115348 114214 113308 111529 115456 114154 111942 112884 111744  total = 30.538008 per ms 
02:20:49.896 16  switches: flows:  123158 125195 123619 119653 120535 122795 120971 122913 119631 118928 117230 119713 118950 118085 119299 117213  total = 32.077944 per ms 
02:21:49.996 16  switches: flows:  117522 119346 117547 115827 115490 118123 116436 116881 113850 115100 112769 113841 113729 114031 114459 112835  total = 30.745126 per ms 
02:22:50.096 16  switches: flows:  114262 115328 113717 112513 112706 114701 113731 113419 111782 110545 110321 111318 111338 110321 110294 108953  total = 29.870962 per ms 
02:23:50.197 16  switches: flows:  119347 119628 122253 116870 118348 119994 120739 120127 119160 116579 115434 117687 118319 114580 115694 114838  total = 31.440695 per ms 
02:24:50.297 16  switches: flows:  120065 119636 122018 119679 117875 120938 121407 119696 120494 117482 115277 118717 118854 113882 116118 116464  total = 31.590626 per ms 
02:25:50.397 16  switches: flows:  118720 119377 120803 116570 118186 120233 119426 118022 118275 115852 113580 116370 118239 112238 114299 114555  total = 31.193648 per ms 
02:26:50.498 16  switches: flows:  122400 121554 123995 120572 119749 123145 122276 121428 120354 119678 117321 119714 120276 116195 117167 118576  total = 32.019696 per ms 
02:27:50.598 16  switches: flows:  122917 123633 124653 121263 119409 124093 122800 120133 120852 119737 117618 121070 120594 116591 117636 119412  total = 32.153148 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29870.96/32153.15/31292.21/10456.78 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.608917" elapsed="0.000546"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-02T02:27:50.609690" elapsed="0.000541"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-02T02:27:50.610789" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-02T02:27:50.610918" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 29870.96/32153.15/31292.21/10456.78 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-02T02:27:50.610470" elapsed="0.000482"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:27:50.611562" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 29870.96/32153.15/31292.21/10456.78 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:27:50.611190" elapsed="0.000413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.614894" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.611820" elapsed="0.003133"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.617540" level="INFO">29870.96/32153.15/31292.21/10456.78</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.615101" elapsed="0.002515"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:27:50.620033" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:27:50.617770" elapsed="0.002291"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-02T02:27:50.622555" level="INFO">@{result_value_list} = [ 29870.96 | 32153.15 | 31292.21 | 10456.78 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-02T02:27:50.620272" elapsed="0.002311"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.623060" level="INFO">Length is 4.</msg>
<msg time="2026-04-02T02:27:50.623165" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-02T02:27:50.622747" elapsed="0.000444"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.628031" level="INFO">min :: 29870.96</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.623583" elapsed="0.004506"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-02T02:27:50.623452" elapsed="0.004688"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.632735" level="INFO">max :: 32153.15</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.628361" elapsed="0.004437"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-02T02:27:50.628233" elapsed="0.004603"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.637476" level="INFO">avg :: 31292.21</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.633050" elapsed="0.004510"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-02T02:27:50.632922" elapsed="0.004673"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.642326" level="INFO">stdev :: 10456.78</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.637814" elapsed="0.004569"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-02T02:27:50.637681" elapsed="0.004737"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-02T02:27:50.623262" elapsed="0.019186"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.646445" level="INFO">${min} = 29870.96</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:27:50.642611" elapsed="0.003862"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.650797" level="INFO">${max} = 32153.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-04-02T02:27:50.646631" elapsed="0.004198"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.654849" level="INFO">${average} = 31292.21</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:27:50.650991" elapsed="0.003886"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.658892" level="INFO">${stdev} = 10456.78</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-02T02:27:50.655033" elapsed="0.003886"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.659473" level="INFO">${date} = 2026-04-02 02:27:50</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-02T02:27:50.659083" elapsed="0.000417"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.660068" level="INFO">CBench Result: 2026-04-02 02:27:50,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,29870.96,32153.15,31292.21,10456.78</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-02T02:27:50.659657" elapsed="0.000484"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-02T02:27:50.661253" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/bug.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/bug.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-02T02:27:50.660766" elapsed="0.000561"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-02T02:27:50.661506" elapsed="0.000469"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-02T02:27:50.660293" elapsed="0.001747"/>
</kw>
<arg>-m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${latency_threshold}</arg>
<arg>bug.csv</arg>
<status status="PASS" start="2026-04-02T02:17:43.933271" elapsed="606.728828"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.662660" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-02T02:27:50.662277" elapsed="0.000447"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-02T02:27:50.663960" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-02T02:27:50.663477" elapsed="0.000510"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-04-02T02:27:50.664227" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-04-02T02:27:50.664061" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-04-02T02:27:50.664041" elapsed="0.000278"/>
</if>
<kw name="Comment" owner="BuiltIn">
<arg>Jira tickets are {PROJECT}-{NUMBER} while Bugzilla tickets are {NUMBER}</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.664466" elapsed="0.000021"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<var>${match}</var>
<arg>Should Contain</arg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.664624" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${bug_url}</var>
<arg>${match}</arg>
<arg>https://jira.opendaylight.org/browse/${number}</arg>
<arg>https://bugs.opendaylight.org/show_bug.cgi?id=${number}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.664785" elapsed="0.000019"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>This test fails due to ${bug_url}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.664981" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.665156" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.665317" elapsed="0.000022"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.665484" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="&quot;${include_bug_in_tags}&quot;==&quot;True&quot;">
<kw name="Set Tags" owner="BuiltIn">
<arg>${bug_url}</arg>
<doc>Adds given ``tags`` for the current test or all tests in a suite.</doc>
<status status="NOT RUN" start="2026-04-02T02:27:50.665716" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-02T02:27:50.665577" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-04-02T02:27:50.665560" elapsed="0.000235"/>
</if>
<arg>6176</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-04-02T02:27:50.663109" elapsed="0.002737"/>
</kw>
<doc>cbench executed in latency mode to see if controller is healthy</doc>
<tag>cbench</tag>
<tag>latency</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-02T02:17:43.931936" elapsed="606.733956"/>
</test>
<doc>Cbench Latency and Throughput tests can be run from an external
cbench.
If cbench is run with a medium number of switches or higher (e.g. 32+)
the normal openflow operations seem to break.
BUG: https://bugs.opendaylight.org/show_bug.cgi?id=2897</doc>
<status status="PASS" start="2026-04-02T01:57:27.816773" elapsed="1822.849697"/>
</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>
