<?xml version="1.0" encoding="UTF-8"?>
<robot generator="Robot 7.4.2 (Python 3.11.10 on linux)" generated="2026-06-01T00:45:07.659969" rpa="false" schemaversion="5">
<suite id="s1" name="openflowplugin-cbench.txt" source="/w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/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-06-01T00:45:08.249577" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-01T00:45:08.249410" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-01T00:45:08.249380" elapsed="0.000299"/>
</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-06-01T00:45:08.249825" elapsed="0.000512"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-01T00:45:08.250835" level="INFO">Logging into '10.30.171.230:8101' as 'karaf'.</msg>
<msg time="2026-06-01T00:45:08.940569" 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-06-01T00:45:08.250515" elapsed="0.690450"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-01T00:45:08.990921" 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-06-01T00:45:08.941260" elapsed="0.049734"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-01T00:45:08.992724" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-06-01T00:45:08.992841" 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-06-01T00:45:08.991167" elapsed="0.001704"/>
</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-06-01T00:45:08.993031" elapsed="0.000232"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T00:45:08.993432" elapsed="0.000245"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:45:08.994181" 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-06-01T00:45:08.993834" elapsed="0.000403"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-01T00:45:08.994292" elapsed="0.000068"/>
</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.230
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-06-01T00:45:08.249029" elapsed="0.745489"/>
</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-06-01T00:45:08.245313" elapsed="0.749321"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-01T00:45:08.995341" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/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-06-01T00:45:08.994876" elapsed="0.000540"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-01T00:45:08.995989" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/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-06-01T00:45:08.995640" elapsed="0.000411"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-01T00:45:08.996751" 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-06-01T00:45:08.996251" elapsed="0.000529"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-01T00:45:08.997291" 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-06-01T00:45:08.996953" elapsed="0.000381"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-01T00:45:08.997882" 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-06-01T00:45:08.997483" elapsed="0.000427"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-01T00:45:08.998386" 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-06-01T00:45:08.998073" elapsed="0.000356"/>
</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-06-01T00:45:08.998757" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-01T00:45:08.998517" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Verify File Exists On Remote System" owner="Utils">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-01T00:45:09.003203" 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-06-01T00:45:09.002794" elapsed="0.000437"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-01T00:45:09.004788" level="INFO">Length is 0.</msg>
<msg time="2026-06-01T00:45:09.004876" 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-06-01T00:45:09.003949" elapsed="0.000952"/>
</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-06-01T00:45:09.005053" elapsed="0.000376"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-01T00:45:09.006508" level="INFO">Logging into '10.30.170.174:22' as 'jenkins'.</msg>
<msg time="2026-06-01T00:45:09.727386" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Mon Jun  1 00:45:09 UTC 2026

  System load:  0.03               Processes:             109
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.170.174
  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-63164-277-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-06-01T00:45:09.005971" elapsed="0.721630"/>
</kw>
<msg time="2026-06-01T00:45:09.727694" 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-06-01T00:45:09.005611" elapsed="0.722180"/>
</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-06-01T00:45:09.003484" elapsed="0.724431"/>
</kw>
<kw name="File Should Exist" owner="SSHLibrary">
<msg time="2026-06-01T00:45:09.735824" 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-06-01T00:45:09.728159" elapsed="0.009705"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T00:45:09.738243" elapsed="0.000593"/>
</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-06-01T00:45:09.002250" elapsed="0.736720"/>
</kw>
<status status="PASS" start="2026-06-01T00:45:08.998893" elapsed="0.740158"/>
</branch>
<status status="PASS" start="2026-06-01T00:45:08.998493" elapsed="0.740621"/>
</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-06-01T00:45:09.739440" elapsed="0.001047"/>
</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-06-01T00:45:09.749449" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-01T00:45:09.749324" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-01T00:45:09.749300" elapsed="0.000229"/>
</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-06-01T00:45:09.753147" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-01T00:45:09.753033" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-01T00:45:09.753013" 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-06-01T00:45:09.753350" elapsed="0.000460"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-01T00:45:09.754221" level="INFO">Logging into '10.30.171.230:8101' as 'karaf'.</msg>
<msg time="2026-06-01T00:45:09.965801" 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-06-01T00:45:09.753959" elapsed="0.212069"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.062413" 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-06-01T00:45:09.966309" elapsed="0.096273"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.089509" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.21.3           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-06-01T00:45:10.089941" level="INFO">${output} = [?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.21.3           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-06-01T00:45:10.062835" elapsed="0.027145"/>
</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-06-01T00:45:10.090245" elapsed="0.000386"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T00:45:10.090798" elapsed="0.000234"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:45:10.091517" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.21.3           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-06-01T00:45:10.091180" elapsed="0.000466"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-01T00:45:10.091703" elapsed="0.000084"/>
</return>
<msg time="2026-06-01T00:45:10.091979" level="INFO">${output} = [?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.21.3           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.230
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-06-01T00:45:09.752671" elapsed="0.339347"/>
</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-06-01T00:45:10.092182" elapsed="0.000637"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-01T00:45:10.092873" elapsed="0.000034"/>
</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-06-01T00:45:09.749012" elapsed="0.344001"/>
</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-06-01T00:45:10.097072" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-01T00:45:10.096935" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-01T00:45:10.096911" elapsed="0.000234"/>
</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-06-01T00:45:10.097282" elapsed="0.000745"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.098471" level="INFO">Logging into '10.30.171.230:8101' as 'karaf'.</msg>
<msg time="2026-06-01T00:45:10.275577" 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-06-01T00:45:10.098196" elapsed="0.177607"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.317511" 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-06-01T00:45:10.276175" elapsed="0.041460"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.319631" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-06-01T00:45:10.319762" 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-06-01T00:45:10.317806" elapsed="0.001986"/>
</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-06-01T00:45:10.319932" elapsed="0.000199"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T00:45:10.320280" elapsed="0.000245"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:45:10.321025" 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-06-01T00:45:10.320697" elapsed="0.000378"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-01T00:45:10.321128" elapsed="0.000058"/>
</return>
<arg>dropallpacketsrpc on</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.171.230
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-06-01T00:45:10.096583" elapsed="0.224725"/>
</kw>
<status status="PASS" start="2026-06-01T00:45:08.243219" elapsed="2.078153"/>
</kw>
<test id="s1-t1" name="Cbench Latency Test" line="37">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:45:10.323811" 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-06-01T00:45:10.322683" elapsed="0.001192"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-01T00:45:10.325340" 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-06-01T00:45:10.324988" elapsed="0.000394"/>
</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-06-01T00:45:10.325723" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-01T00:45:10.325463" elapsed="0.000319"/>
</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-06-01T00:45:10.328864" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-01T00:45:10.328606" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-01T00:45:10.328583" elapsed="0.000365"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.329287" 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-06-01T00:45:10.329410" 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-06-01T00:45:10.329080" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:45:10.330014" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.230 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.170.174" 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-06-01T00:45:10.329589" elapsed="0.000486"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.330701" 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-06-01T00:45:10.330215" elapsed="0.000512"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-01T00:45:10.331660" level="INFO">Length is 0.</msg>
<msg time="2026-06-01T00:45:10.331754" 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-06-01T00:45:10.331302" elapsed="0.000476"/>
</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-06-01T00:45:10.331922" elapsed="0.000334"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.333133" level="INFO">Logging into '10.30.170.174:22' as 'jenkins'.</msg>
<msg time="2026-06-01T00:45:10.650913" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Mon Jun  1 00:45:09 UTC 2026

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


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Mon Jun  1 00:45:09 2026 from 10.30.170.186
[?2004h[jenkins@releng-63164-277-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-06-01T00:45:10.332775" elapsed="0.318299"/>
</kw>
<msg time="2026-06-01T00:45:10.651149" 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-06-01T00:45:10.332410" elapsed="0.318827"/>
</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-06-01T00:45:10.330928" elapsed="0.320419"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-01T00:45:10.652146" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.230 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-06-01T00:55:16.759921" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-01T00:55:16.760512" level="INFO">${stdout} = </msg>
<msg time="2026-06-01T00:55:16.760665" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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-06-01T00:45:10.651592" elapsed="606.109136"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T00:55:16.761231" elapsed="0.000755"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.763105" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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.230. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
00:46:15.863 16  switches: flows:  116286 115831 112009 111947 113780 115642 113221 114960 112548 111047 110954 111364 114118 112443 110444 113658  total = 30.170867 per ms 
00:47:15.964 16  switches: flows:  129093 125298 124505 123231 126626 125244 125187 123727 121869 121948 124668 123527 121055 122284 120018 124588  total = 32.992731 per ms 
00:48:16.064 16  switches: flows:  125171 123610 122681 119314 124056 121196 121868 120369 117579 119126 122824 121247 118410 119688 117685 121280  total = 32.214628 per ms 
00:49:16.165 16  switches: flows:  130593 130501 130615 124247 130193 128209 128571 125056 123806 124924 126463 125623 123594 124982 124432 128383  total = 33.780101 per ms 
00:50:16.265 16  switches: flows:  131338 131424 130980 126267 129236 127481 128587 127512 124193 124325 125624 127438 123443 125977 126181 128347  total = 33.915860 per ms 
00:51:16.365 16  switches: flows:  131287 131513 131806 126800 131984 128957 128330 127563 125167 123550 126639 129342 124926 128631 124890 128358  total = 34.105459 per ms 
00:52:16.466 16  switches: flows:  128641 131086 127961 125373 129979 126417 127139 126329 121776 121311 123871 125933 124607 125434 123212 126495  total = 33.536673 per ms 
00:53:16.566 16  switches: flows:  128697 127618 127571 124785 127408 126706 126089 125317 121398 121770 122490 124260 123261 123721 120300 124569  total = 33.210552 per ms 
00:54:16.666 16  switches: flows:  129942 127076 129445 126526 129082 128276 127382 125256 123627 123263 124026 122816 124232 122414 122866 125680  total = 33.475928 per ms 
00:55:16.766 16  switches: flows:  128404 129721 128512 126624 126855 129311 126173 126047 123278 125152 125190 122910 123417 123184 123080 126320  total = 33.513667 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 32214.63/34105.46/33416.18/11151.44 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T00:55:16.762350" elapsed="0.001098"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-06-01T00:55:16.763997" elapsed="0.000087"/>
</return>
<status status="PASS" start="2026-06-01T00:55:16.763688" elapsed="0.000480"/>
</branch>
<status status="PASS" start="2026-06-01T00:55:16.763622" elapsed="0.000604"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-01T00:55:16.764445" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-01T00:55:16.764360" elapsed="0.000177"/>
</branch>
<status status="NOT RUN" start="2026-06-01T00:55:16.764324" elapsed="0.000294"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-01T00:55:16.764695" elapsed="0.000032"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-01T00:55:16.768718" elapsed="0.000470"/>
</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-06-01T00:55:16.769394" elapsed="0.000248"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T00:55:16.769827" elapsed="0.000138"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-01T00:55:16.765431" elapsed="0.004607"/>
</kw>
<msg time="2026-06-01T00:55:16.770217" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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-06-01T00:45:10.326129" elapsed="606.444126"/>
</kw>
<status status="PASS" start="2026-06-01T00:45:10.325811" elapsed="606.444514"/>
</branch>
<status status="PASS" start="2026-06-01T00:45:10.325440" elapsed="606.444917"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.770977" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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.230. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
00:46:15.863 16  switches: flows:  116286 115831 112009 111947 113780 115642 113221 114960 112548 111047 110954 111364 114118 112443 110444 113658  total = 30.170867 per ms 
00:47:15.964 16  switches: flows:  129093 125298 124505 123231 126626 125244 125187 123727 121869 121948 124668 123527 121055 122284 120018 124588  total = 32.992731 per ms 
00:48:16.064 16  switches: flows:  125171 123610 122681 119314 124056 121196 121868 120369 117579 119126 122824 121247 118410 119688 117685 121280  total = 32.214628 per ms 
00:49:16.165 16  switches: flows:  130593 130501 130615 124247 130193 128209 128571 125056 123806 124924 126463 125623 123594 124982 124432 128383  total = 33.780101 per ms 
00:50:16.265 16  switches: flows:  131338 131424 130980 126267 129236 127481 128587 127512 124193 124325 125624 127438 123443 125977 126181 128347  total = 33.915860 per ms 
00:51:16.365 16  switches: flows:  131287 131513 131806 126800 131984 128957 128330 127563 125167 123550 126639 129342 124926 128631 124890 128358  total = 34.105459 per ms 
00:52:16.466 16  switches: flows:  128641 131086 127961 125373 129979 126417 127139 126329 121776 121311 123871 125933 124607 125434 123212 126495  total = 33.536673 per ms 
00:53:16.566 16  switches: flows:  128697 127618 127571 124785 127408 126706 126089 125317 121398 121770 122490 124260 123261 123721 120300 124569  total = 33.210552 per ms 
00:54:16.666 16  switches: flows:  129942 127076 129445 126526 129082 128276 127382 125256 123627 123263 124026 122816 124232 122414 122866 125680  total = 33.475928 per ms 
00:55:16.766 16  switches: flows:  128404 129721 128512 126624 126855 129311 126173 126047 123278 125152 125190 122910 123417 123184 123080 126320  total = 33.513667 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 32214.63/34105.46/33416.18/11151.44 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T00:55:16.770572" elapsed="0.000508"/>
</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-06-01T00:55:16.771284" elapsed="0.000532"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-06-01T00:55:16.772351" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-06-01T00:55:16.772478" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 32214.63/34105.46/33416.18/11151.44 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-06-01T00:55:16.772040" elapsed="0.000472"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T00:55:16.773163" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 32214.63/34105.46/33416.18/11151.44 | 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-06-01T00:55:16.772750" elapsed="0.000452"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.776545" 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-06-01T00:55:16.773405" elapsed="0.003240"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.779469" level="INFO">32214.63/34105.46/33416.18/11151.44</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T00:55:16.776896" elapsed="0.002637"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T00:55:16.782095" 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-06-01T00:55:16.779698" elapsed="0.002425"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T00:55:16.784544" level="INFO">@{result_value_list} = [ 32214.63 | 34105.46 | 33416.18 | 11151.44 ]</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-06-01T00:55:16.782314" elapsed="0.002272"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.785067" level="INFO">Length is 4.</msg>
<msg time="2026-06-01T00:55:16.785155" 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-06-01T00:55:16.784742" elapsed="0.000437"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.789924" level="INFO">min :: 32214.63</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-06-01T00:55:16.785589" elapsed="0.004392"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-06-01T00:55:16.785441" elapsed="0.004575"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.794570" level="INFO">max :: 34105.46</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-06-01T00:55:16.790236" elapsed="0.004392"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-01T00:55:16.790109" elapsed="0.004553"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.799315" level="INFO">avg :: 33416.18</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-06-01T00:55:16.794877" elapsed="0.004494"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-06-01T00:55:16.794750" elapsed="0.004655"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.804303" level="INFO">stdev :: 11151.44</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-06-01T00:55:16.799646" elapsed="0.004715"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-06-01T00:55:16.799498" elapsed="0.004898"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-06-01T00:55:16.785249" elapsed="0.019180"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.808360" level="INFO">${min} = 32214.63</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-06-01T00:55:16.804605" elapsed="0.003782"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.812269" level="INFO">${max} = 34105.46</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-06-01T00:55:16.808539" elapsed="0.003757"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.816362" level="INFO">${average} = 33416.18</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-06-01T00:55:16.812448" elapsed="0.003940"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.820313" level="INFO">${stdev} = 11151.44</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-06-01T00:55:16.816540" elapsed="0.003800"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.820882" level="INFO">${date} = 2026-06-01 00:55:16</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-06-01T00:55:16.820498" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.821460" level="INFO">CBench Result: 2026-06-01 00:55:16,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,32214.63,34105.46,33416.18,11151.44</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-06-01T00:55:16.821055" elapsed="0.000460"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-01T00:55:16.822534" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/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-06-01T00:55:16.822135" elapsed="0.000481"/>
</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-06-01T00:55:16.822768" 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-06-01T00:55:16.821666" elapsed="0.001617"/>
</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-06-01T00:45:10.324328" elapsed="606.499016"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.823825" 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-06-01T00:55:16.823495" elapsed="0.000386"/>
</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-06-01T00:55:16.824390" elapsed="0.000280"/>
</kw>
<status status="PASS" start="2026-06-01T00:55:16.824092" elapsed="0.000649"/>
</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-06-01T00:45:10.321571" elapsed="606.503234"/>
</test>
<test id="s1-t2" name="Cbench Throughput Test" line="51">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.826245" 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-06-01T00:55:16.825860" elapsed="0.000442"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.827542" 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-06-01T00:55:16.827210" elapsed="0.000392"/>
</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-06-01T00:55:16.827936" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-01T00:55:16.827708" elapsed="0.000287"/>
</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-06-01T00:55:16.831039" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-01T00:55:16.830792" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-01T00:55:16.830772" elapsed="0.000347"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-01T00:55:16.831433" 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-06-01T00:55:16.831565" 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-06-01T00:55:16.831248" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.832149" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.230 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.170.174" 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-06-01T00:55:16.831728" elapsed="0.000478"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-01T00:55:16.832767" 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-06-01T00:55:16.832344" elapsed="0.000451"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-01T00:55:16.833699" level="INFO">Length is 0.</msg>
<msg time="2026-06-01T00:55:16.833791" 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-06-01T00:55:16.833366" elapsed="0.000449"/>
</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-06-01T00:55:16.833955" elapsed="0.000323"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-01T00:55:16.835145" level="INFO">Logging into '10.30.170.174:22' as 'jenkins'.</msg>
<msg time="2026-06-01T00:55:17.473517" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Mon Jun  1 00:55:17 UTC 2026

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


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Mon Jun  1 00:45:10 2026 from 10.30.170.186
[?2004h[jenkins@releng-63164-277-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-06-01T00:55:16.834791" elapsed="0.638942"/>
</kw>
<msg time="2026-06-01T00:55:17.473823" 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-06-01T00:55:16.834430" elapsed="0.639484"/>
</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-06-01T00:55:16.832995" elapsed="0.641035"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-01T00:55:17.474601" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.230 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-06-01T01:05:23.508671" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-01T01:05:23.509226" level="INFO">${stdout} = </msg>
<msg time="2026-06-01T01:05:23.509332" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.230: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-06-01T00:55:17.474256" elapsed="606.035133"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T01:05:23.509868" elapsed="0.000730"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.511717" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.230: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.230. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
00:56:22.613 16  switches: flows:  557777 553188 556457 576511 570007 560147 565075 561788 556719 557343 554626 552311 542404 554520 549022 554625  total = 148.708667 per ms 
00:57:22.715 16  switches: flows:  552722 558094 552846 554799 546496 552908 558897 546970 556038 543218 558915 545826 558253 550502 546666 550097  total = 146.973156 per ms 
00:58:22.816 16  switches: flows:  558846 584465 587999 591091 587021 591197 582154 584330 592942 603605 581626 597220 582546 576515 595387 584406  total = 156.094040 per ms 
00:59:22.919 16  switches: flows:  586108 597563 581873 582710 584935 588302 581045 583874 577988 588664 585371 589904 576082 581862 589116 584475  total = 155.733372 per ms 
01:00:23.020 16  switches: flows:  557339 566985 554161 553480 563908 559102 562370 556200 559895 547896 556031 564188 554421 554371 561937 572083  total = 148.822018 per ms 
01:01:23.122 16  switches: flows:  603137 597880 602964 604048 603540 596182 595421 597895 607277 604707 608809 601967 601524 596405 605035 593641  total = 160.070689 per ms 
01:02:23.223 16  switches: flows:  615752 625483 620398 617608 604226 608697 610729 595977 622599 615524 601862 620244 618137 603748 618386 617229  total = 163.334892 per ms 
01:03:23.325 16  switches: flows:  592462 587614 584915 581879 594784 595796 588953 581934 599390 589762 584157 589086 581826 580392 582250 585473  total = 156.413237 per ms 
01:04:23.426 16  switches: flows:  602772 611286 612824 611449 606692 603677 610409 611179 618188 614908 609073 622221 611496 608193 606956 607373  total = 162.537897 per ms 
01:05:23.527 16  switches: flows:  594302 589953 595911 596131 584094 588366 597704 592772 589331 589757 593521 601114 590722 584252 595925 590045  total = 157.633108 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 146973.16/163334.89/156401.38/52396.97 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T01:05:23.510968" 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-06-01T01:05:23.512614" elapsed="0.000096"/>
</return>
<status status="PASS" start="2026-06-01T01:05:23.512236" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-01T01:05:23.512184" elapsed="0.000673"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-01T01:05:23.513072" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-01T01:05:23.512989" elapsed="0.000174"/>
</branch>
<status status="NOT RUN" start="2026-06-01T01:05:23.512952" elapsed="0.000259"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-01T01:05:23.513281" elapsed="0.000031"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-01T01:05:23.517937" elapsed="0.000327"/>
</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-06-01T01:05:23.518412" elapsed="0.000181"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T01:05:23.518723" elapsed="0.000111"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-01T01:05:23.513981" elapsed="0.004907"/>
</kw>
<msg time="2026-06-01T01:05:23.519016" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.230: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-06-01T00:55:16.828334" elapsed="606.690709"/>
</kw>
<status status="PASS" start="2026-06-01T00:55:16.828020" elapsed="606.691072"/>
</branch>
<status status="PASS" start="2026-06-01T00:55:16.827687" elapsed="606.691429"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.519546" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.230: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.230. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
00:56:22.613 16  switches: flows:  557777 553188 556457 576511 570007 560147 565075 561788 556719 557343 554626 552311 542404 554520 549022 554625  total = 148.708667 per ms 
00:57:22.715 16  switches: flows:  552722 558094 552846 554799 546496 552908 558897 546970 556038 543218 558915 545826 558253 550502 546666 550097  total = 146.973156 per ms 
00:58:22.816 16  switches: flows:  558846 584465 587999 591091 587021 591197 582154 584330 592942 603605 581626 597220 582546 576515 595387 584406  total = 156.094040 per ms 
00:59:22.919 16  switches: flows:  586108 597563 581873 582710 584935 588302 581045 583874 577988 588664 585371 589904 576082 581862 589116 584475  total = 155.733372 per ms 
01:00:23.020 16  switches: flows:  557339 566985 554161 553480 563908 559102 562370 556200 559895 547896 556031 564188 554421 554371 561937 572083  total = 148.822018 per ms 
01:01:23.122 16  switches: flows:  603137 597880 602964 604048 603540 596182 595421 597895 607277 604707 608809 601967 601524 596405 605035 593641  total = 160.070689 per ms 
01:02:23.223 16  switches: flows:  615752 625483 620398 617608 604226 608697 610729 595977 622599 615524 601862 620244 618137 603748 618386 617229  total = 163.334892 per ms 
01:03:23.325 16  switches: flows:  592462 587614 584915 581879 594784 595796 588953 581934 599390 589762 584157 589086 581826 580392 582250 585473  total = 156.413237 per ms 
01:04:23.426 16  switches: flows:  602772 611286 612824 611449 606692 603677 610409 611179 618188 614908 609073 622221 611496 608193 606956 607373  total = 162.537897 per ms 
01:05:23.527 16  switches: flows:  594302 589953 595911 596131 584094 588366 597704 592772 589331 589757 593521 601114 590722 584252 595925 590045  total = 157.633108 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 146973.16/163334.89/156401.38/52396.97 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T01:05:23.519259" elapsed="0.000378"/>
</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-06-01T01:05:23.519786" elapsed="0.000367"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-06-01T01:05:23.520561" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-06-01T01:05:23.520654" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 146973.16/163334.89/156401.38/52396.97 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-06-01T01:05:23.520314" elapsed="0.000365"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T01:05:23.521089" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 146973.16/163334.89/156401.38/52396.97 | 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-06-01T01:05:23.520833" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.523528" 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-06-01T01:05:23.521276" elapsed="0.002323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.525992" level="INFO">146973.16/163334.89/156401.38/52396.97</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T01:05:23.523745" elapsed="0.002303"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T01:05:23.528443" 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-06-01T01:05:23.526199" elapsed="0.002273"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T01:05:23.530911" level="INFO">@{result_value_list} = [ 146973.16 | 163334.89 | 156401.38 | 52396.97 ]</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-06-01T01:05:23.528675" elapsed="0.002265"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.531399" level="INFO">Length is 4.</msg>
<msg time="2026-06-01T01:05:23.531493" 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-06-01T01:05:23.531095" elapsed="0.000423"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.536245" level="INFO">min :: 146973.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-06-01T01:05:23.531906" elapsed="0.004395"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-06-01T01:05:23.531775" elapsed="0.004561"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.541119" level="INFO">max :: 163334.89</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-06-01T01:05:23.536580" elapsed="0.004597"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-01T01:05:23.536437" elapsed="0.004775"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.545780" level="INFO">avg :: 156401.38</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-06-01T01:05:23.541430" elapsed="0.004406"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-06-01T01:05:23.541301" elapsed="0.004570"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.550415" level="INFO">stdev :: 52396.97</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T01:05:23.546086" elapsed="0.004384"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-06-01T01:05:23.545958" elapsed="0.004547"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-06-01T01:05:23.531597" elapsed="0.018939"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.554588" level="INFO">${min} = 146973.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-06-01T01:05:23.550712" elapsed="0.003904"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.558529" level="INFO">${max} = 163334.89</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-06-01T01:05:23.554773" elapsed="0.003802"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.562849" level="INFO">${average} = 156401.38</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-06-01T01:05:23.558730" elapsed="0.004146"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.566811" level="INFO">${stdev} = 52396.97</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-06-01T01:05:23.563028" elapsed="0.003810"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.567346" level="INFO">${date} = 2026-06-01 01:05:23</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-06-01T01:05:23.566997" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.567955" level="INFO">CBench Result: 2026-06-01 01:05:23,-t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,146973.16,163334.89,156401.38,52396.97</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-06-01T01:05:23.567529" elapsed="0.000482"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-01T01:05:23.569061" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/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-06-01T01:05:23.568649" elapsed="0.000478"/>
</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-06-01T01:05:23.569279" elapsed="0.000481"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-06-01T01:05:23.568148" elapsed="0.001677"/>
</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-06-01T00:55:16.826627" elapsed="606.743259"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.570352" 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-06-01T01:05:23.570038" elapsed="0.000371"/>
</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-06-01T01:05:23.570934" elapsed="0.000267"/>
</kw>
<status status="PASS" start="2026-06-01T01:05:23.570631" elapsed="0.000641"/>
</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-06-01T00:55:16.825237" elapsed="606.746075"/>
</test>
<test id="s1-t3" name="Rerun Latency Test To Check Bug 6176" line="65">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.572874" 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-06-01T01:05:23.572475" elapsed="0.000455"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.574265" 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-06-01T01:05:23.573817" elapsed="0.000491"/>
</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-06-01T01:05:23.574690" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-01T01:05:23.574418" elapsed="0.000332"/>
</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-06-01T01:05:23.577695" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-01T01:05:23.577430" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-01T01:05:23.577411" elapsed="0.000364"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-01T01:05:23.578087" 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-06-01T01:05:23.578203" 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-06-01T01:05:23.577907" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.578798" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.230 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.170.174" 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-06-01T01:05:23.578364" elapsed="0.000491"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-01T01:05:23.579382" 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-06-01T01:05:23.578994" elapsed="0.000415"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-01T01:05:23.580459" level="INFO">Length is 0.</msg>
<msg time="2026-06-01T01:05:23.580568" 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-06-01T01:05:23.579996" elapsed="0.000598"/>
</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-06-01T01:05:23.580738" elapsed="0.000323"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-01T01:05:23.581930" level="INFO">Logging into '10.30.170.174:22' as 'jenkins'.</msg>
<msg time="2026-06-01T01:05:24.160541" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Mon Jun  1 01:05:23 UTC 2026

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


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Mon Jun  1 00:55:17 2026 from 10.30.170.186
[?2004h[jenkins@releng-63164-277-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-06-01T01:05:23.581573" elapsed="0.579230"/>
</kw>
<msg time="2026-06-01T01:05:24.160901" 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-06-01T01:05:23.581212" elapsed="0.579775"/>
</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-06-01T01:05:23.579624" elapsed="0.581485"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-01T01:05:24.161738" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.230 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-06-01T01:15:30.251789" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-01T01:15:30.252419" level="INFO">${stdout} = </msg>
<msg time="2026-06-01T01:15:30.252534" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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-06-01T01:05:24.161363" elapsed="606.091269"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T01:15:30.253153" elapsed="0.000853"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.255234" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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.230. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:06:29.372 16  switches: flows:  116573 117202 119475 116965 115941 117651 116716 118530 115174 116034 114642 115599 113800 114065 114748 112566  total = 30.928017 per ms 
01:07:29.473 16  switches: flows:  130238 127261 128653 129465 128835 127901 128346 127004 125922 127509 126317 125766 127457 127257 125789 126834  total = 33.952538 per ms 
01:08:29.574 16  switches: flows:  132447 128496 130235 129025 131088 128832 127808 127711 126799 129552 125974 124134 127747 129565 128845 127352  total = 34.203030 per ms 
01:09:29.675 16  switches: flows:  133485 128811 131689 129976 131152 129768 127407 130367 128098 129431 126662 125880 127067 130516 128054 129933  total = 34.414112 per ms 
01:10:29.776 16  switches: flows:  132618 128998 132093 129399 129782 129932 128829 129871 126320 129755 127086 125076 126975 129194 127479 127211  total = 34.286356 per ms 
01:11:29.878 16  switches: flows:  120450 119286 120861 119233 121189 120433 116447 118924 116228 120580 116647 114454 118161 119857 117562 118407  total = 31.592549 per ms 
01:12:29.979 16  switches: flows:  128928 132081 132263 126796 126912 129062 127973 130635 127479 129142 127125 126580 129264 126806 127096 126821  total = 34.192300 per ms 
01:13:30.080 16  switches: flows:  127929 128896 130690 126744 125889 128676 124991 129199 126725 127148 124042 126446 128575 126890 125438 124331  total = 33.820340 per ms 
01:14:30.181 16  switches: flows:  128954 131456 131038 127051 126824 128674 127058 129338 128336 127830 125879 127717 129434 128122 128426 123603  total = 34.105378 per ms 
01:15:30.282 16  switches: flows:  129382 131185 133754 126674 126229 129065 127223 131466 128964 128184 125530 127511 130141 128752 129052 126336  total = 34.266916 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 31592.55/34414.11/33870.39/11320.07 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T01:15:30.254417" elapsed="0.001203"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-06-01T01:15:30.256158" elapsed="0.000097"/>
</return>
<status status="PASS" start="2026-06-01T01:15:30.255830" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-01T01:15:30.255774" elapsed="0.000635"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-01T01:15:30.256669" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-06-01T01:15:30.256546" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-01T01:15:30.256508" elapsed="0.000312"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-01T01:15:30.256895" elapsed="0.000032"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-01T01:15:30.263035" elapsed="0.000371"/>
</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-06-01T01:15:30.263568" elapsed="0.000164"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-01T01:15:30.263861" elapsed="0.000113"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-01T01:15:30.257640" elapsed="0.006388"/>
</kw>
<msg time="2026-06-01T01:15:30.264157" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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-06-01T01:05:23.575096" elapsed="606.689088"/>
</kw>
<status status="PASS" start="2026-06-01T01:05:23.574776" elapsed="606.689457"/>
</branch>
<status status="PASS" start="2026-06-01T01:05:23.574396" elapsed="606.689861"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.264707" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.230: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.230. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
01:06:29.372 16  switches: flows:  116573 117202 119475 116965 115941 117651 116716 118530 115174 116034 114642 115599 113800 114065 114748 112566  total = 30.928017 per ms 
01:07:29.473 16  switches: flows:  130238 127261 128653 129465 128835 127901 128346 127004 125922 127509 126317 125766 127457 127257 125789 126834  total = 33.952538 per ms 
01:08:29.574 16  switches: flows:  132447 128496 130235 129025 131088 128832 127808 127711 126799 129552 125974 124134 127747 129565 128845 127352  total = 34.203030 per ms 
01:09:29.675 16  switches: flows:  133485 128811 131689 129976 131152 129768 127407 130367 128098 129431 126662 125880 127067 130516 128054 129933  total = 34.414112 per ms 
01:10:29.776 16  switches: flows:  132618 128998 132093 129399 129782 129932 128829 129871 126320 129755 127086 125076 126975 129194 127479 127211  total = 34.286356 per ms 
01:11:29.878 16  switches: flows:  120450 119286 120861 119233 121189 120433 116447 118924 116228 120580 116647 114454 118161 119857 117562 118407  total = 31.592549 per ms 
01:12:29.979 16  switches: flows:  128928 132081 132263 126796 126912 129062 127973 130635 127479 129142 127125 126580 129264 126806 127096 126821  total = 34.192300 per ms 
01:13:30.080 16  switches: flows:  127929 128896 130690 126744 125889 128676 124991 129199 126725 127148 124042 126446 128575 126890 125438 124331  total = 33.820340 per ms 
01:14:30.181 16  switches: flows:  128954 131456 131038 127051 126824 128674 127058 129338 128336 127830 125879 127717 129434 128122 128426 123603  total = 34.105378 per ms 
01:15:30.282 16  switches: flows:  129382 131185 133754 126674 126229 129065 127223 131466 128964 128184 125530 127511 130141 128752 129052 126336  total = 34.266916 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 31592.55/34414.11/33870.39/11320.07 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T01:15:30.264404" elapsed="0.000377"/>
</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-06-01T01:15:30.264930" elapsed="0.000552"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-06-01T01:15:30.265877" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-06-01T01:15:30.265968" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 31592.55/34414.11/33870.39/11320.07 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-06-01T01:15:30.265658" elapsed="0.000334"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T01:15:30.266432" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 31592.55/34414.11/33870.39/11320.07 | 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-06-01T01:15:30.266167" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.268877" 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-06-01T01:15:30.266625" elapsed="0.002309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.271498" level="INFO">31592.55/34414.11/33870.39/11320.07</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-01T01:15:30.269080" elapsed="0.002489"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T01:15:30.273985" 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-06-01T01:15:30.271720" elapsed="0.002292"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-01T01:15:30.276448" level="INFO">@{result_value_list} = [ 31592.55 | 34414.11 | 33870.39 | 11320.07 ]</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-06-01T01:15:30.274206" elapsed="0.002269"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.276951" level="INFO">Length is 4.</msg>
<msg time="2026-06-01T01:15:30.277039" 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-06-01T01:15:30.276646" elapsed="0.000417"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.281785" level="INFO">min :: 31592.55</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-06-01T01:15:30.277434" elapsed="0.004407"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-06-01T01:15:30.277306" elapsed="0.004570"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.286463" level="INFO">max :: 34414.11</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-06-01T01:15:30.282088" elapsed="0.004432"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-01T01:15:30.281962" elapsed="0.004609"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.291140" level="INFO">avg :: 33870.39</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-06-01T01:15:30.286784" elapsed="0.004413"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-06-01T01:15:30.286656" elapsed="0.004575"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.295828" level="INFO">stdev :: 11320.07</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-06-01T01:15:30.291442" elapsed="0.004442"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-06-01T01:15:30.291316" elapsed="0.004602"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-06-01T01:15:30.277126" elapsed="0.018822"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.299857" level="INFO">${min} = 31592.55</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-06-01T01:15:30.296106" elapsed="0.003778"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.304080" level="INFO">${max} = 34414.11</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-06-01T01:15:30.300038" elapsed="0.004070"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.308064" level="INFO">${average} = 33870.39</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-06-01T01:15:30.304264" elapsed="0.003827"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.312302" level="INFO">${stdev} = 11320.07</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-06-01T01:15:30.308245" elapsed="0.004084"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.312866" level="INFO">${date} = 2026-06-01 01:15:30</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-06-01T01:15:30.312498" elapsed="0.000393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.313456" level="INFO">CBench Result: 2026-06-01 01:15:30,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,31592.55,34414.11,33870.39,11320.07</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-06-01T01:15:30.313038" elapsed="0.000498"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-01T01:15:30.314683" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/bug.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-vanadium/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-06-01T01:15:30.314189" elapsed="0.000563"/>
</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-06-01T01:15:30.314903" elapsed="0.000468"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-06-01T01:15:30.313706" elapsed="0.001729"/>
</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-06-01T01:05:23.573244" elapsed="606.742251"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.315968" 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-06-01T01:15:30.315658" elapsed="0.000366"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-01T01:15:30.317221" 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-06-01T01:15:30.316748" elapsed="0.000500"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-01T01:15:30.317469" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-01T01:15:30.317323" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-01T01:15:30.317303" elapsed="0.000274"/>
</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-06-01T01:15:30.317724" 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-06-01T01:15:30.317881" elapsed="0.000020"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${bug_url}</var>
<arg>${match}</arg>
<arg>https://jira.opendaylight.org/browse/${number}</arg>
<arg>https://bugs.opendaylight.org/show_bug.cgi?id=${number}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-01T01:15:30.318039" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>This test fails due to ${bug_url}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-01T01:15:30.318235" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-01T01:15:30.318448" elapsed="0.000025"/>
</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-06-01T01:15:30.318629" elapsed="0.000021"/>
</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-06-01T01:15:30.318777" elapsed="0.000019"/>
</kw>
<if>
<branch type="IF" condition="&quot;${include_bug_in_tags}&quot;==&quot;True&quot;">
<kw name="Set Tags" owner="BuiltIn">
<arg>${bug_url}</arg>
<doc>Adds given ``tags`` for the current test or all tests in a suite.</doc>
<status status="NOT RUN" start="2026-06-01T01:15:30.318995" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-01T01:15:30.318860" elapsed="0.000187"/>
</branch>
<status status="NOT RUN" start="2026-06-01T01:15:30.318842" elapsed="0.000229"/>
</if>
<arg>6176</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-01T01:15:30.316399" elapsed="0.002723"/>
</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-06-01T01:05:23.571868" elapsed="606.747300"/>
</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-06-01T00:45:07.661601" elapsed="1822.658051"/>
</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>
