<?xml version="1.0" encoding="UTF-8"?>
<robot generator="Robot 7.4.2 (Python 3.11.10 on linux)" generated="2026-06-20T00:45:30.996348" 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-20T00:45:31.602184" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-20T00:45:31.602024" elapsed="0.000263"/>
</branch>
<status status="PASS" start="2026-06-20T00:45:31.601983" elapsed="0.000335"/>
</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-20T00:45:31.602469" elapsed="0.000655"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-20T00:45:31.603663" level="INFO">Logging into '10.30.171.236:8101' as 'karaf'.</msg>
<msg time="2026-06-20T00:45:32.508753" 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-20T00:45:31.603314" elapsed="0.905762"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-20T00:45:32.557915" 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-20T00:45:32.509536" elapsed="0.048455"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-20T00:45:32.559765" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-06-20T00:45:32.559895" 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-20T00:45:32.558165" elapsed="0.001761"/>
</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-20T00:45:32.560099" elapsed="0.000226"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T00:45:32.560489" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:45:32.561380" 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-20T00:45:32.560943" elapsed="0.000491"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-20T00:45:32.561495" elapsed="0.000086"/>
</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.236
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-20T00:45:31.601601" elapsed="0.960161"/>
</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-20T00:45:31.597821" elapsed="0.964021"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-20T00:45:32.562564" 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-20T00:45:32.562084" elapsed="0.000537"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-20T00:45:32.563046" 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-20T00:45:32.562795" elapsed="0.000333"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-20T00:45:32.563740" 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-20T00:45:32.563287" elapsed="0.000480"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-20T00:45:32.564340" 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-20T00:45:32.563949" elapsed="0.000433"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-20T00:45:32.564933" 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-20T00:45:32.564528" elapsed="0.000431"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-20T00:45:32.565427" 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-20T00:45:32.565118" elapsed="0.000350"/>
</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-20T00:45:32.565843" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-20T00:45:32.565588" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Verify File Exists On Remote System" owner="Utils">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-20T00:45:32.570965" 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-20T00:45:32.570483" elapsed="0.000509"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-20T00:45:32.572207" level="INFO">Length is 0.</msg>
<msg time="2026-06-20T00:45:32.572289" 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-20T00:45:32.571554" elapsed="0.000760"/>
</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-20T00:45:32.572459" elapsed="0.000370"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-20T00:45:32.573923" level="INFO">Logging into '10.30.171.16:22' as 'jenkins'.</msg>
<msg time="2026-06-20T00:45:33.283682" 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 Sat Jun 20 00:45:32 UTC 2026

  System load:  0.04               Processes:             110
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.16
  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-315-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-20T00:45:32.573345" elapsed="0.710534"/>
</kw>
<msg time="2026-06-20T00:45:33.283988" 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-20T00:45:32.572992" elapsed="0.711108"/>
</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-20T00:45:32.571200" elapsed="0.713063"/>
</kw>
<kw name="File Should Exist" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.292321" 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-20T00:45:33.284521" elapsed="0.009270"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T00:45:33.294004" elapsed="0.000322"/>
</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-20T00:45:32.569917" elapsed="0.724477"/>
</kw>
<status status="PASS" start="2026-06-20T00:45:32.566215" elapsed="0.728218"/>
</branch>
<status status="PASS" start="2026-06-20T00:45:32.565549" elapsed="0.728924"/>
</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-20T00:45:33.294654" elapsed="0.000532"/>
</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-20T00:45:33.299692" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-20T00:45:33.299552" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-20T00:45:33.299527" elapsed="0.000243"/>
</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-20T00:45:33.303334" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-20T00:45:33.303221" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-20T00:45:33.303201" elapsed="0.000203"/>
</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-20T00:45:33.303540" elapsed="0.000468"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.304428" level="INFO">Logging into '10.30.171.236:8101' as 'karaf'.</msg>
<msg time="2026-06-20T00:45:33.490393" 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-20T00:45:33.304156" elapsed="0.186342"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.576114" 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-20T00:45:33.490693" elapsed="0.085522"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.580429" 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-20T00:45:33.580657" 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-20T00:45:33.576406" elapsed="0.004284"/>
</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-20T00:45:33.580835" elapsed="0.000209"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T00:45:33.581195" elapsed="0.000219"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:45:33.581881" 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-20T00:45:33.581553" elapsed="0.000384"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-20T00:45:33.581985" elapsed="0.000051"/>
</return>
<msg time="2026-06-20T00:45:33.582182" 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.236
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-20T00:45:33.302865" elapsed="0.279350"/>
</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-20T00:45:33.582367" elapsed="0.000660"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-20T00:45:33.583077" elapsed="0.000032"/>
</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-20T00:45:33.299235" elapsed="0.283977"/>
</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-20T00:45:33.586958" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-20T00:45:33.586838" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-20T00:45:33.586816" elapsed="0.000213"/>
</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-20T00:45:33.587159" elapsed="0.000431"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.588233" level="INFO">Logging into '10.30.171.236:8101' as 'karaf'.</msg>
<msg time="2026-06-20T00:45:33.747088" 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-20T00:45:33.587760" elapsed="0.159434"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.769066" 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-20T00:45:33.747380" elapsed="0.021748"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.770900" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-06-20T00:45:33.770999" 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-20T00:45:33.769280" elapsed="0.001748"/>
</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-20T00:45:33.771159" elapsed="0.000194"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T00:45:33.771502" elapsed="0.000194"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:45:33.772130" 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-20T00:45:33.771835" elapsed="0.000345"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-20T00:45:33.772228" elapsed="0.000046"/>
</return>
<arg>dropallpacketsrpc on</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.171.236
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-20T00:45:33.586502" elapsed="0.185911"/>
</kw>
<status status="PASS" start="2026-06-20T00:45:31.595680" elapsed="2.176827"/>
</kw>
<test id="s1-t1" name="Cbench Latency Test" line="37">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:45:33.774935" 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-20T00:45:33.773467" elapsed="0.001558"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-20T00:45:33.776772" 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-20T00:45:33.776354" elapsed="0.000463"/>
</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-20T00:45:33.777137" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-20T00:45:33.776902" elapsed="0.000294"/>
</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-20T00:45:33.780356" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-20T00:45:33.780075" elapsed="0.000340"/>
</branch>
<status status="PASS" start="2026-06-20T00:45:33.780055" elapsed="0.000387"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.780818" 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-20T00:45:33.780950" 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-20T00:45:33.780581" elapsed="0.000397"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:45:33.781549" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.236 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.16" 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-20T00:45:33.781117" elapsed="0.000493"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.782269" 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-20T00:45:33.781770" elapsed="0.000526"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-20T00:45:33.783241" level="INFO">Length is 0.</msg>
<msg time="2026-06-20T00:45:33.783332" 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-20T00:45:33.782899" elapsed="0.000458"/>
</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-20T00:45:33.783503" elapsed="0.000369"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-20T00:45:33.784802" level="INFO">Logging into '10.30.171.16:22' as 'jenkins'.</msg>
<msg time="2026-06-20T00:45:34.110495" 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 Sat Jun 20 00:45:32 UTC 2026

  System load:  0.04               Processes:             110
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.16
  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: Sat Jun 20 00:45:33 2026 from 10.30.171.191
[?2004h[jenkins@releng-63164-315-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-20T00:45:33.784424" elapsed="0.326229"/>
</kw>
<msg time="2026-06-20T00:45:34.110733" 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-20T00:45:33.784036" elapsed="0.326778"/>
</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-20T00:45:33.782503" elapsed="0.328413"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-20T00:45:34.111343" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.236 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-06-20T00:55:40.216872" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-20T00:55:40.217468" level="INFO">${stdout} = </msg>
<msg time="2026-06-20T00:55:40.217579" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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-20T00:45:34.111099" elapsed="606.106571"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T00:55:40.218289" elapsed="0.000813"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.220384" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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.236. 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:39.314 16  switches: flows:  117015 118552 118076 118032 117611 115708 114258 116080 113265 114834 110985 111543 109024 114678 112680 109997  total = 30.538967 per ms 
00:47:39.415 16  switches: flows:  128902 126762 127818 130825 128383 127156 126440 127740 121591 124341 123990 126677 121180 122529 124402 121167  total = 33.442558 per ms 
00:48:39.515 16  switches: flows:  126446 123002 125554 127129 127514 125249 124543 123536 124737 124187 119415 121003 121543 119859 124738 121412  total = 32.942807 per ms 
00:49:39.615 16  switches: flows:  132972 131596 132404 134479 133961 131834 130640 129813 127962 131401 124721 127294 124171 125254 127193 129223  total = 34.524321 per ms 
00:50:39.715 16  switches: flows:  131689 128614 130797 131442 130986 130679 128690 128997 125606 127264 125658 124762 122772 124018 124769 126398  total = 33.995626 per ms 
00:51:39.816 16  switches: flows:  133751 130002 130671 133266 132543 131922 129464 133837 128342 129813 127235 127612 125563 126419 128933 127708  total = 34.560329 per ms 
00:52:39.916 16  switches: flows:  133306 132452 132087 134381 134467 134154 131546 132341 130905 131435 129155 128378 129024 128105 130995 127826  total = 34.950872 per ms 
00:53:40.016 16  switches: flows:  129275 127908 132428 132172 129939 132202 128464 129923 129054 127099 125482 127655 127238 124838 126032 127025  total = 34.221766 per ms 
00:54:40.117 16  switches: flows:  131186 128857 134475 136291 129019 133982 132691 129945 131072 129647 127245 127454 128126 124398 127453 128021  total = 34.606619 per ms 
00:55:40.217 16  switches: flows:  131645 131743 135035 136291 131044 134030 130439 129014 131383 130596 127765 129134 127537 126874 127121 128193  total = 34.739375 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 32942.81/34950.87/34220.47/11423.60 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T00:55:40.219500" elapsed="0.001229"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-06-20T00:55:40.221301" elapsed="0.000091"/>
</return>
<status status="PASS" start="2026-06-20T00:55:40.220943" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-20T00:55:40.220882" elapsed="0.000653"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-20T00:55:40.221790" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-20T00:55:40.221704" elapsed="0.000178"/>
</branch>
<status status="NOT RUN" start="2026-06-20T00:55:40.221664" elapsed="0.000265"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-20T00:55:40.222003" elapsed="0.000030"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-20T00:55:40.226559" elapsed="0.000376"/>
</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-20T00:55:40.227082" elapsed="0.000230"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T00:55:40.227457" elapsed="0.000102"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-20T00:55:40.222791" elapsed="0.004824"/>
</kw>
<msg time="2026-06-20T00:55:40.227767" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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-20T00:45:33.777571" elapsed="606.450222"/>
</kw>
<status status="PASS" start="2026-06-20T00:45:33.777227" elapsed="606.450616"/>
</branch>
<status status="PASS" start="2026-06-20T00:45:33.776879" elapsed="606.450989"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.228318" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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.236. 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:39.314 16  switches: flows:  117015 118552 118076 118032 117611 115708 114258 116080 113265 114834 110985 111543 109024 114678 112680 109997  total = 30.538967 per ms 
00:47:39.415 16  switches: flows:  128902 126762 127818 130825 128383 127156 126440 127740 121591 124341 123990 126677 121180 122529 124402 121167  total = 33.442558 per ms 
00:48:39.515 16  switches: flows:  126446 123002 125554 127129 127514 125249 124543 123536 124737 124187 119415 121003 121543 119859 124738 121412  total = 32.942807 per ms 
00:49:39.615 16  switches: flows:  132972 131596 132404 134479 133961 131834 130640 129813 127962 131401 124721 127294 124171 125254 127193 129223  total = 34.524321 per ms 
00:50:39.715 16  switches: flows:  131689 128614 130797 131442 130986 130679 128690 128997 125606 127264 125658 124762 122772 124018 124769 126398  total = 33.995626 per ms 
00:51:39.816 16  switches: flows:  133751 130002 130671 133266 132543 131922 129464 133837 128342 129813 127235 127612 125563 126419 128933 127708  total = 34.560329 per ms 
00:52:39.916 16  switches: flows:  133306 132452 132087 134381 134467 134154 131546 132341 130905 131435 129155 128378 129024 128105 130995 127826  total = 34.950872 per ms 
00:53:40.016 16  switches: flows:  129275 127908 132428 132172 129939 132202 128464 129923 129054 127099 125482 127655 127238 124838 126032 127025  total = 34.221766 per ms 
00:54:40.117 16  switches: flows:  131186 128857 134475 136291 129019 133982 132691 129945 131072 129647 127245 127454 128126 124398 127453 128021  total = 34.606619 per ms 
00:55:40.217 16  switches: flows:  131645 131743 135035 136291 131044 134030 130439 129014 131383 130596 127765 129134 127537 126874 127121 128193  total = 34.739375 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 32942.81/34950.87/34220.47/11423.60 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T00:55:40.228009" elapsed="0.000383"/>
</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-20T00:55:40.228541" elapsed="0.000429"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-06-20T00:55:40.229378" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-06-20T00:55:40.229467" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 32942.81/34950.87/34220.47/11423.60 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-20T00:55:40.229134" elapsed="0.000358"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T00:55:40.229933" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 32942.81/34950.87/34220.47/11423.60 | 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-20T00:55:40.229668" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.232364" 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-20T00:55:40.230102" elapsed="0.002318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.234808" level="INFO">32942.81/34950.87/34220.47/11423.60</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T00:55:40.232569" elapsed="0.002301"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T00:55:40.237251" 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-20T00:55:40.235019" elapsed="0.002259"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T00:55:40.239725" level="INFO">@{result_value_list} = [ 32942.81 | 34950.87 | 34220.47 | 11423.60 ]</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-20T00:55:40.237464" elapsed="0.002291"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.240248" level="INFO">Length is 4.</msg>
<msg time="2026-06-20T00:55:40.240337" 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-20T00:55:40.239913" elapsed="0.000447"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.245156" level="INFO">min :: 32942.81</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-20T00:55:40.240834" elapsed="0.004378"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-06-20T00:55:40.240692" elapsed="0.004555"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.249830" level="INFO">max :: 34950.87</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-20T00:55:40.245467" elapsed="0.004422"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-20T00:55:40.245341" elapsed="0.004586"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.254471" level="INFO">avg :: 34220.47</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-20T00:55:40.250141" elapsed="0.004393"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-06-20T00:55:40.250014" elapsed="0.004554"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.259118" level="INFO">stdev :: 11423.60</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-20T00:55:40.254806" elapsed="0.004368"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-06-20T00:55:40.254675" elapsed="0.004533"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-06-20T00:55:40.240447" elapsed="0.018793"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.263264" level="INFO">${min} = 32942.81</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-20T00:55:40.259403" elapsed="0.003887"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.267574" level="INFO">${max} = 34950.87</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-20T00:55:40.263442" elapsed="0.004158"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.271817" level="INFO">${average} = 34220.47</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-20T00:55:40.267768" elapsed="0.004075"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.275801" level="INFO">${stdev} = 11423.60</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-20T00:55:40.271993" elapsed="0.003835"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.276385" level="INFO">${date} = 2026-06-20 00:55:40</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-20T00:55:40.275995" elapsed="0.000416"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.276989" level="INFO">CBench Result: 2026-06-20 00:55:40,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,32942.81,34950.87,34220.47,11423.60</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-20T00:55:40.276555" elapsed="0.000489"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-20T00:55:40.278244" 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-20T00:55:40.277767" elapsed="0.000543"/>
</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-20T00:55:40.278462" elapsed="0.000493"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-06-20T00:55:40.277223" elapsed="0.001800"/>
</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-20T00:45:33.775485" elapsed="606.503602"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.279583" 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-20T00:55:40.279241" elapsed="0.000413"/>
</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-20T00:55:40.280224" elapsed="0.000276"/>
</kw>
<status status="PASS" start="2026-06-20T00:55:40.279896" elapsed="0.000675"/>
</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-20T00:45:33.772713" elapsed="606.507898"/>
</test>
<test id="s1-t2" name="Cbench Throughput Test" line="51">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.281980" 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-20T00:55:40.281581" elapsed="0.000484"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.283366" 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-20T00:55:40.283025" elapsed="0.000382"/>
</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-20T00:55:40.283783" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-20T00:55:40.283534" elapsed="0.000312"/>
</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-20T00:55:40.286887" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-20T00:55:40.286569" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-20T00:55:40.286550" elapsed="0.000418"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-20T00:55:40.287361" 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-20T00:55:40.287484" 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-20T00:55:40.287112" elapsed="0.000400"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.288081" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.236 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.16" 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-20T00:55:40.287660" elapsed="0.000488"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-20T00:55:40.288748" 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-20T00:55:40.288325" elapsed="0.000451"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-20T00:55:40.289710" level="INFO">Length is 0.</msg>
<msg time="2026-06-20T00:55:40.289800" 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-20T00:55:40.289366" elapsed="0.000458"/>
</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-20T00:55:40.289970" elapsed="0.000338"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-20T00:55:40.291191" level="INFO">Logging into '10.30.171.16:22' as 'jenkins'.</msg>
<msg time="2026-06-20T00:55:40.888710" 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 Sat Jun 20 00:55:40 UTC 2026

  System load:  1.02               Processes:             103
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.16
  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: Sat Jun 20 00:45:34 2026 from 10.30.171.191
[?2004h[jenkins@releng-63164-315-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-20T00:55:40.290828" elapsed="0.598171"/>
</kw>
<msg time="2026-06-20T00:55:40.889114" 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-20T00:55:40.290461" elapsed="0.598779"/>
</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-20T00:55:40.288984" elapsed="0.600407"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-20T00:55:40.890231" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.236 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-06-20T01:05:47.467561" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-20T01:05:47.470214" level="INFO">${stdout} = </msg>
<msg time="2026-06-20T01:05:47.470324" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.236: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-20T00:55:40.889739" elapsed="606.580642"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T01:05:47.471893" elapsed="0.001085"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.475157" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.236: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.236. 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:46.015 16  switches: flows:  503209 475886 513885 491936 471307 495651 506241 493497 494092 493809 480302 498870 468905 488006 476226 501072  total = 130.881567 per ms 
00:57:46.428 16  switches: flows:  466440 477928 461506 466769 432811 460161 464031 462651 467932 457349 466154 461344 466532 459739 458844 451430  total = 122.189843 per ms 
00:58:46.529 16  switches: flows:  555608 556033 552424 551625 549067 556219 558995 553222 524991 552029 551590 549966 564207 551766 551925 547377  total = 146.870408 per ms 
00:59:46.630 16  switches: flows:  551106 538157 541211 545315 547302 529299 536206 542001 537425 546124 538716 554588 536045 548278 551902 529550  total = 144.310889 per ms 
01:00:46.731 16  switches: flows:  529176 529362 532132 530918 532281 532217 531972 528622 530662 528115 527786 531860 521053 531034 527153 531772  total = 141.031854 per ms 
01:01:46.832 16  switches: flows:  501545 502703 507284 502243 501413 503402 501631 505164 510716 503430 501089 502173 500244 503229 501085 506898  total = 134.013478 per ms 
01:02:47.016 16  switches: flows:  510099 507385 509315 509563 510269 507577 512964 503659 506998 509332 509938 504693 507780 508069 505346 508122  total = 135.105244 per ms 
01:03:47.261 16  switches: flows:  544694 541756 553856 549369 541806 547270 546431 549743 547183 551466 549537 539987 542676 548287 545030 548504  total = 145.202735 per ms 
01:04:47.362 16  switches: flows:  502661 495303 499949 497566 492109 506177 505404 493201 493807 495810 493940 497564 505972 499652 503719 501726  total = 132.852898 per ms 
01:05:47.464 16  switches: flows:  520233 512841 521538 523425 523860 518765 519905 513155 527407 519152 513625 513766 513687 515539 521258 524330  total = 138.140395 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 122189.84/146870.41/137746.42/46492.32 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T01:05:47.473877" elapsed="0.001585"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-06-20T01:05:47.476467" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-20T01:05:47.476253" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-20T01:05:47.476197" elapsed="0.000371"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-20T01:05:47.476722" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-20T01:05:47.476625" elapsed="0.000139"/>
</branch>
<status status="NOT RUN" start="2026-06-20T01:05:47.476609" elapsed="0.000177"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-20T01:05:47.476817" elapsed="0.000013"/>
</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-20T01:05:47.479345" elapsed="0.000346"/>
</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-20T01:05:47.479849" elapsed="0.000180"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T01:05:47.480158" elapsed="0.000103"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-20T01:05:47.477153" elapsed="0.003161"/>
</kw>
<msg time="2026-06-20T01:05:47.480449" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.236: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-20T00:55:40.284238" elapsed="607.196237"/>
</kw>
<status status="PASS" start="2026-06-20T00:55:40.283873" elapsed="607.196651"/>
</branch>
<status status="PASS" start="2026-06-20T00:55:40.283510" elapsed="607.197038"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.481003" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.171.236: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.236. 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:46.015 16  switches: flows:  503209 475886 513885 491936 471307 495651 506241 493497 494092 493809 480302 498870 468905 488006 476226 501072  total = 130.881567 per ms 
00:57:46.428 16  switches: flows:  466440 477928 461506 466769 432811 460161 464031 462651 467932 457349 466154 461344 466532 459739 458844 451430  total = 122.189843 per ms 
00:58:46.529 16  switches: flows:  555608 556033 552424 551625 549067 556219 558995 553222 524991 552029 551590 549966 564207 551766 551925 547377  total = 146.870408 per ms 
00:59:46.630 16  switches: flows:  551106 538157 541211 545315 547302 529299 536206 542001 537425 546124 538716 554588 536045 548278 551902 529550  total = 144.310889 per ms 
01:00:46.731 16  switches: flows:  529176 529362 532132 530918 532281 532217 531972 528622 530662 528115 527786 531860 521053 531034 527153 531772  total = 141.031854 per ms 
01:01:46.832 16  switches: flows:  501545 502703 507284 502243 501413 503402 501631 505164 510716 503430 501089 502173 500244 503229 501085 506898  total = 134.013478 per ms 
01:02:47.016 16  switches: flows:  510099 507385 509315 509563 510269 507577 512964 503659 506998 509332 509938 504693 507780 508069 505346 508122  total = 135.105244 per ms 
01:03:47.261 16  switches: flows:  544694 541756 553856 549369 541806 547270 546431 549743 547183 551466 549537 539987 542676 548287 545030 548504  total = 145.202735 per ms 
01:04:47.362 16  switches: flows:  502661 495303 499949 497566 492109 506177 505404 493201 493807 495810 493940 497564 505972 499652 503719 501726  total = 132.852898 per ms 
01:05:47.464 16  switches: flows:  520233 512841 521538 523425 523860 518765 519905 513155 527407 519152 513625 513766 513687 515539 521258 524330  total = 138.140395 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 122189.84/146870.41/137746.42/46492.32 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T01:05:47.480712" elapsed="0.000364"/>
</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-20T01:05:47.481223" elapsed="0.000362"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-06-20T01:05:47.481989" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-06-20T01:05:47.482079" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 122189.84/146870.41/137746.42/46492.32 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-20T01:05:47.481757" elapsed="0.000347"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T01:05:47.482515" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 122189.84/146870.41/137746.42/46492.32 | 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-20T01:05:47.482264" elapsed="0.000279"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.484957" 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-20T01:05:47.482702" elapsed="0.002312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.487364" level="INFO">122189.84/146870.41/137746.42/46492.32</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T01:05:47.485159" elapsed="0.002261"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T01:05:47.489795" 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-20T01:05:47.487566" elapsed="0.002256"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T01:05:47.492442" level="INFO">@{result_value_list} = [ 122189.84 | 146870.41 | 137746.42 | 46492.32 ]</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-20T01:05:47.490012" elapsed="0.002457"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.492941" level="INFO">Length is 4.</msg>
<msg time="2026-06-20T01:05:47.493028" 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-20T01:05:47.492621" elapsed="0.000431"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.497888" level="INFO">min :: 122189.84</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-20T01:05:47.493425" elapsed="0.004520"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-06-20T01:05:47.493298" elapsed="0.004681"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.502475" level="INFO">max :: 146870.41</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-20T01:05:47.498194" elapsed="0.004336"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-20T01:05:47.498069" elapsed="0.004495"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.507119" level="INFO">avg :: 137746.42</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-20T01:05:47.502793" elapsed="0.004383"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-06-20T01:05:47.502667" elapsed="0.004543"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.511797" level="INFO">stdev :: 46492.32</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-20T01:05:47.507431" elapsed="0.004423"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-06-20T01:05:47.507298" elapsed="0.004590"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-06-20T01:05:47.493117" elapsed="0.018803"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.515779" level="INFO">${min} = 122189.84</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-20T01:05:47.512074" elapsed="0.003736"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.519902" level="INFO">${max} = 146870.41</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-20T01:05:47.515960" elapsed="0.003969"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.524009" level="INFO">${average} = 137746.42</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-20T01:05:47.520078" elapsed="0.003958"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.527917" level="INFO">${stdev} = 46492.32</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-20T01:05:47.524186" elapsed="0.003758"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.528446" level="INFO">${date} = 2026-06-20 01:05:47</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-20T01:05:47.528101" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.529044" level="INFO">CBench Result: 2026-06-20 01:05:47,-t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,122189.84,146870.41,137746.42,46492.32</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-20T01:05:47.528620" elapsed="0.000479"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-20T01:05:47.530129" 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-20T01:05:47.529719" elapsed="0.000476"/>
</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-20T01:05:47.530344" elapsed="0.000484"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-06-20T01:05:47.529237" elapsed="0.001657"/>
</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-20T00:55:40.282418" elapsed="607.248535"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.531558" 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-20T01:05:47.531244" elapsed="0.000370"/>
</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-20T01:05:47.532185" elapsed="0.000266"/>
</kw>
<status status="PASS" start="2026-06-20T01:05:47.531888" elapsed="0.000634"/>
</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-20T00:55:40.280976" elapsed="607.251584"/>
</test>
<test id="s1-t3" name="Rerun Latency Test To Check Bug 6176" line="65">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.534300" 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-20T01:05:47.533923" elapsed="0.000433"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.537414" 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-20T01:05:47.536568" elapsed="0.000952"/>
</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-20T01:05:47.538405" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-20T01:05:47.537892" elapsed="0.000643"/>
</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-20T01:05:47.545215" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-20T01:05:47.544808" elapsed="0.000496"/>
</branch>
<status status="PASS" start="2026-06-20T01:05:47.544775" elapsed="0.000564"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-20T01:05:47.545905" 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-20T01:05:47.546095" 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-20T01:05:47.545538" elapsed="0.000597"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.547032" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.171.236 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.16" 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-20T01:05:47.546333" elapsed="0.000786"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-20T01:05:47.547953" 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-20T01:05:47.547324" elapsed="0.000674"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-20T01:05:47.549360" level="INFO">Length is 0.</msg>
<msg time="2026-06-20T01:05:47.549489" 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-20T01:05:47.548890" elapsed="0.000635"/>
</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-20T01:05:47.549758" elapsed="0.000499"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-20T01:05:47.551558" level="INFO">Logging into '10.30.171.16:22' as 'jenkins'.</msg>
<msg time="2026-06-20T01:05:48.157552" 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 Sat Jun 20 01:05:47 UTC 2026

  System load:  0.21               Processes:             106
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.16
  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: Sat Jun 20 00:55:40 2026 from 10.30.171.191
[?2004h[jenkins@releng-63164-315-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-20T01:05:47.551010" elapsed="0.606747"/>
</kw>
<msg time="2026-06-20T01:05:48.157846" 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-20T01:05:47.550481" elapsed="0.607452"/>
</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-20T01:05:47.548304" elapsed="0.609748"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-20T01:05:48.158621" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.171.236 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-06-20T01:15:54.273405" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-20T01:15:54.277762" level="INFO">${stdout} = </msg>
<msg time="2026-06-20T01:15:54.277858" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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-20T01:05:48.158293" elapsed="606.119606"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T01:15:54.280169" elapsed="0.002200"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.283279" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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.236. 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:53.336 16  switches: flows:  124458 125386 122615 122381 134379 121506 123163 121240 120739 123304 126498 120583 121173 119686 117703 119761  total = 32.742917 per ms 
01:07:53.436 16  switches: flows:  116974 119394 118173 118671 116222 115948 118789 118141 116008 116595 114722 115992 115002 114817 114154 117342  total = 31.063829 per ms 
01:08:53.537 16  switches: flows:  117244 119346 117632 116568 117040 115094 117980 114327 114909 112587 112963 116222 116165 114381 114650 115845  total = 30.831063 per ms 
01:09:53.637 16  switches: flows:  122605 123109 122193 120260 119513 120847 121531 118380 122416 118671 120600 121543 120977 120733 118227 119221  total = 32.126797 per ms 
01:10:53.737 16  switches: flows:  126361 130107 125605 127053 126940 126163 128842 125667 125226 125933 127341 126750 126983 125937 124891 126467  total = 33.714782 per ms 
01:11:53.838 16  switches: flows:  119698 123252 119095 119841 120863 117905 123087 118243 119528 120359 120672 120273 121464 118349 118847 118360  total = 31.943922 per ms 
01:12:53.938 16  switches: flows:  127388 130087 127255 127762 127050 125098 127927 125989 126480 127225 125920 125903 126190 125133 124051 124581  total = 33.677689 per ms 
01:13:54.038 16  switches: flows:  128880 129233 128280 127994 126827 126659 128941 126513 128301 127616 129005 127268 127308 125830 126652 126972  total = 33.981183 per ms 
01:14:54.139 16  switches: flows:  117521 120090 117573 118333 117093 116141 116251 116672 116850 117270 117935 118112 116593 116064 115667 116671  total = 31.195196 per ms 
01:15:54.239 16  switches: flows:  117957 115738 115028 115065 114377 113419 115833 115813 113806 114875 114921 115065 116524 113743 113885 111828  total = 30.580177 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 30580.18/33981.18/32123.85/10782.75 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T01:15:54.282709" elapsed="0.001326"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-06-20T01:15:54.284397" elapsed="0.000053"/>
</return>
<status status="PASS" start="2026-06-20T01:15:54.284178" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-20T01:15:54.284141" elapsed="0.000397"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-20T01:15:54.284692" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-20T01:15:54.284619" elapsed="0.000131"/>
</branch>
<status status="NOT RUN" start="2026-06-20T01:15:54.284596" elapsed="0.000185"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-20T01:15:54.284825" elapsed="0.000024"/>
</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-20T01:15:54.289655" elapsed="0.000510"/>
</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-20T01:15:54.290401" elapsed="0.001206"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-20T01:15:54.291818" elapsed="0.000150"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-20T01:15:54.285313" elapsed="0.006737"/>
</kw>
<msg time="2026-06-20T01:15:54.292242" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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-20T01:05:47.539365" elapsed="606.752917"/>
</kw>
<status status="PASS" start="2026-06-20T01:05:47.538591" elapsed="606.753764"/>
</branch>
<status status="PASS" start="2026-06-20T01:05:47.537837" elapsed="606.754553"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.293096" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.171.236: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.236. 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:53.336 16  switches: flows:  124458 125386 122615 122381 134379 121506 123163 121240 120739 123304 126498 120583 121173 119686 117703 119761  total = 32.742917 per ms 
01:07:53.436 16  switches: flows:  116974 119394 118173 118671 116222 115948 118789 118141 116008 116595 114722 115992 115002 114817 114154 117342  total = 31.063829 per ms 
01:08:53.537 16  switches: flows:  117244 119346 117632 116568 117040 115094 117980 114327 114909 112587 112963 116222 116165 114381 114650 115845  total = 30.831063 per ms 
01:09:53.637 16  switches: flows:  122605 123109 122193 120260 119513 120847 121531 118380 122416 118671 120600 121543 120977 120733 118227 119221  total = 32.126797 per ms 
01:10:53.737 16  switches: flows:  126361 130107 125605 127053 126940 126163 128842 125667 125226 125933 127341 126750 126983 125937 124891 126467  total = 33.714782 per ms 
01:11:53.838 16  switches: flows:  119698 123252 119095 119841 120863 117905 123087 118243 119528 120359 120672 120273 121464 118349 118847 118360  total = 31.943922 per ms 
01:12:53.938 16  switches: flows:  127388 130087 127255 127762 127050 125098 127927 125989 126480 127225 125920 125903 126190 125133 124051 124581  total = 33.677689 per ms 
01:13:54.038 16  switches: flows:  128880 129233 128280 127994 126827 126659 128941 126513 128301 127616 129005 127268 127308 125830 126652 126972  total = 33.981183 per ms 
01:14:54.139 16  switches: flows:  117521 120090 117573 118333 117093 116141 116251 116672 116850 117270 117935 118112 116593 116064 115667 116671  total = 31.195196 per ms 
01:15:54.239 16  switches: flows:  117957 115738 115028 115065 114377 113419 115833 115813 113806 114875 114921 115065 116524 113743 113885 111828  total = 30.580177 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 30580.18/33981.18/32123.85/10782.75 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T01:15:54.292644" elapsed="0.000562"/>
</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-20T01:15:54.293417" elapsed="0.000536"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-06-20T01:15:54.295033" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-06-20T01:15:54.295799" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 30580.18/33981.18/32123.85/10782.75 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-20T01:15:54.294180" elapsed="0.001716"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T01:15:54.297407" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 30580.18/33981.18/32123.85/10782.75 | 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-20T01:15:54.296540" elapsed="0.000938"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.303450" 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-20T01:15:54.297867" elapsed="0.005712"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.308937" level="INFO">30580.18/33981.18/32123.85/10782.75</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-20T01:15:54.303958" elapsed="0.005105"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T01:15:54.312420" 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-20T01:15:54.309400" elapsed="0.003048"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-20T01:15:54.314981" level="INFO">@{result_value_list} = [ 30580.18 | 33981.18 | 32123.85 | 10782.75 ]</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-20T01:15:54.312722" elapsed="0.002287"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.315518" level="INFO">Length is 4.</msg>
<msg time="2026-06-20T01:15:54.315608" 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-20T01:15:54.315166" elapsed="0.000480"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.320455" level="INFO">min :: 30580.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-20T01:15:54.316135" elapsed="0.004381"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-06-20T01:15:54.316001" elapsed="0.004553"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.325079" level="INFO">max :: 33981.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-20T01:15:54.320814" elapsed="0.004322"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-20T01:15:54.320672" elapsed="0.004499"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.329660" level="INFO">avg :: 32123.85</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-20T01:15:54.325377" elapsed="0.004342"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-06-20T01:15:54.325254" elapsed="0.004500"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.334427" level="INFO">stdev :: 10782.75</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-20T01:15:54.329969" elapsed="0.004519"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-06-20T01:15:54.329839" elapsed="0.004686"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-06-20T01:15:54.315746" elapsed="0.018811"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.338546" level="INFO">${min} = 30580.18</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-20T01:15:54.334759" elapsed="0.003816"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.343464" level="INFO">${max} = 33981.18</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-20T01:15:54.338755" elapsed="0.004736"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.347358" level="INFO">${average} = 32123.85</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-20T01:15:54.343664" elapsed="0.003720"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.351254" level="INFO">${stdev} = 10782.75</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-20T01:15:54.347534" elapsed="0.003745"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.351844" level="INFO">${date} = 2026-06-20 01:15:54</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-20T01:15:54.351440" elapsed="0.000429"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.352619" level="INFO">CBench Result: 2026-06-20 01:15:54,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,30580.18,33981.18,32123.85,10782.75</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-20T01:15:54.352203" elapsed="0.000489"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-06-20T01:15:54.355597" 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-20T01:15:54.353422" elapsed="0.002474"/>
</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-20T01:15:54.356332" elapsed="0.001035"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-06-20T01:15:54.352899" elapsed="0.004593"/>
</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-20T01:05:47.534995" elapsed="606.822605"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.358422" 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-20T01:15:54.357850" elapsed="0.000656"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-20T01:15:54.361044" 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-20T01:15:54.360303" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-20T01:15:54.361443" elapsed="0.000063"/>
</return>
<status status="PASS" start="2026-06-20T01:15:54.361218" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-20T01:15:54.361175" elapsed="0.000423"/>
</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-20T01:15:54.361837" elapsed="0.000031"/>
</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-20T01:15:54.362060" elapsed="0.000029"/>
</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-20T01:15:54.362314" elapsed="0.000031"/>
</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-20T01:15:54.362689" elapsed="0.000031"/>
</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-20T01:15:54.362903" elapsed="0.000028"/>
</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-20T01:15:54.363104" elapsed="0.000028"/>
</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-20T01:15:54.363316" elapsed="0.000028"/>
</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-20T01:15:54.363701" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-20T01:15:54.363439" elapsed="0.000344"/>
</branch>
<status status="NOT RUN" start="2026-06-20T01:15:54.363414" elapsed="0.000403"/>
</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-20T01:15:54.359750" elapsed="0.004142"/>
</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-20T01:05:47.532970" elapsed="606.830988"/>
</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-20T00:45:30.998045" elapsed="1823.368376"/>
</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>
