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

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-24T02:05:46.403815" elapsed="0.844157"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-24T02:05:47.296865" level="INFO">@root&gt;log:set ERROR</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-24T02:05:47.248303" elapsed="0.048694"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-24T02:05:47.298880" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-24T02:05:47.298991" level="INFO">${output} = [?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-24T02:05:47.297288" elapsed="0.001733"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-24T02:05:47.299176" elapsed="0.000274"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:05:47.299608" elapsed="0.000246"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:05:47.300348" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:05:47.300004" elapsed="0.000475"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-24T02:05:47.300533" elapsed="0.000059"/>
</return>
<arg>log:set ${log_level}</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.170.72
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-24T02:05:46.402373" elapsed="0.898342"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>KarafKeywords.Issue Command On Karaf Console</arg>
<arg>log:set ${log_level}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-04-24T02:05:46.398824" elapsed="0.901954"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-24T02:05:47.301344" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv&lt;/a&gt;'.</msg>
<arg>${latency_results_file}</arg>
<arg>LATENCY_MIN,LATENCY_MAX,LATENCY_AVERAGE\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-24T02:05:47.300964" elapsed="0.000464"/>
</kw>
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-24T02:05:47.301828" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv&lt;/a&gt;'.</msg>
<arg>${throughput_results_file}</arg>
<arg>THROUGHPUT_MIN,THROUGHPUT_MAX,THROUGHPUT_AVERAGE\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-24T02:05:47.301581" elapsed="0.000303"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-24T02:05:47.302447" level="INFO">${duration_in_ms} = 60000</msg>
<var>${duration_in_ms}</var>
<arg>${duration_in_secs} * 1000</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-24T02:05:47.302036" elapsed="0.000439"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-24T02:05:47.303007" level="INFO">${duration_in_ms} = 60000</msg>
<arg>${duration_in_ms}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-24T02:05:47.302641" elapsed="0.000408"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-24T02:05:47.303581" level="INFO">${test_timeout} = 900.0</msg>
<var>${test_timeout}</var>
<arg>(${loops} * ${duration_in_secs}) * 1.5</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-24T02:05:47.303193" elapsed="0.000416"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-24T02:05:47.304076" level="INFO">${test_timeout} = 900.0</msg>
<arg>${test_timeout}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-24T02:05:47.303767" elapsed="0.000351"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="File Should Exist" owner="OperatingSystem">
<arg>${cbench_executable}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="NOT RUN" start="2026-04-24T02:05:47.304464" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:05:47.304203" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Verify File Exists On Remote System" owner="Utils">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-24T02:05:47.309075" level="INFO">${conn_id} = 2</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:05:47.308662" elapsed="0.000441"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-24T02:05:47.310146" level="INFO">Length is 0.</msg>
<msg time="2026-04-24T02:05:47.310230" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-24T02:05:47.309675" elapsed="0.000579"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:05:47.310413" elapsed="0.000378"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-24T02:05:47.313983" level="INFO">Logging into '10.30.171.38:22' as 'jenkins'.</msg>
<msg time="2026-04-24T02:05:48.040988" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Fri Apr 24 02:05:47 UTC 2026

  System load:  0.21               Processes:             111
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.38
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


[?2004h[jenkins@releng-48317-699-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-24T02:05:47.312572" elapsed="0.728576"/>
</kw>
<msg time="2026-04-24T02:05:48.041237" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:05:47.311417" elapsed="0.729914"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-24T02:05:47.309316" elapsed="0.732157"/>
</kw>
<kw name="File Should Exist" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.048911" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<arg>${file}</arg>
<doc>Fails if the given ``path`` does NOT point to an existing file.</doc>
<status status="PASS" start="2026-04-24T02:05:48.041682" elapsed="0.009130"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:05:48.051008" elapsed="0.000304"/>
</kw>
<arg>${cbench_system}</arg>
<arg>${cbench_executable}</arg>
<doc>Will create connection with public key and will PASS if the given ${file} exists,
otherwise will FAIL</doc>
<status status="PASS" start="2026-04-24T02:05:47.308117" elapsed="0.743284"/>
</kw>
<status status="PASS" start="2026-04-24T02:05:47.304813" elapsed="0.746635"/>
</branch>
<status status="PASS" start="2026-04-24T02:05:47.304178" elapsed="0.747316"/>
</if>
<kw name="Should Be True" owner="BuiltIn">
<arg>${loops} &gt;= 2</arg>
<arg>If number of loops is less than 2, cbench will not run</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-24T02:05:48.051692" elapsed="0.000524"/>
</kw>
<kw name="Verify_Feature_Is_Installed" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-24T02:05:48.061058" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-04-24T02:05:48.060936" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-04-24T02:05:48.060912" elapsed="0.000223"/>
</if>
<kw name="Issue_Command_On_Karaf_Console" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-24T02:05:48.064684" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-04-24T02:05:48.064569" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-04-24T02:05:48.064549" elapsed="0.000204"/>
</if>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${controller}</arg>
<arg>port=${karaf_port}</arg>
<arg>prompt=${KARAF_PROMPT_LOGIN}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:05:48.064884" elapsed="0.000443"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.065752" level="INFO">Logging into '10.30.170.72:8101' as 'karaf'.</msg>
<msg time="2026-04-24T02:05:48.272633" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-24T02:05:48.065491" elapsed="0.207265"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.365863" level="INFO">@root&gt;feature:list -i | 0[C 0g[Krep odl-openflowplugin-drop-test</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-24T02:05:48.272955" elapsed="0.092977"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.371083" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                                    x OpenDaylight :: Openflow Plugin :: Drop Test
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-24T02:05:48.371255" level="INFO">${output} = [?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                     ...</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-24T02:05:48.366092" elapsed="0.005196"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-24T02:05:48.371451" elapsed="0.000198"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:05:48.371796" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:05:48.372553" level="INFO">[?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                                    x OpenDaylight :: Openflow Plugin :: Drop Test
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:05:48.372219" elapsed="0.000396"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-24T02:05:48.372664" elapsed="0.000051"/>
</return>
<msg time="2026-04-24T02:05:48.372859" level="INFO">${output} = [?1l&gt;[?2004l[31;1modl-openflowplugin-drop-test[0m                                    x 0.20.2           x x        x Started x [31;1modl-openflowplugin-drop-test[0m                     ...</msg>
<var>${output}</var>
<arg>feature:list -i | grep ${feature_name}</arg>
<arg>${controller}</arg>
<arg>${karaf_port}</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.170.72
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-24T02:05:48.064192" elapsed="0.308699"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>${feature_name}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-24T02:05:48.373036" elapsed="0.000545"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-24T02:05:48.373633" 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-04-24T02:05:48.060630" elapsed="0.313132"/>
</kw>
<kw name="Issue_Command_On_Karaf_Console" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-24T02:05:48.377452" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-04-24T02:05:48.377304" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-04-24T02:05:48.377282" elapsed="0.000241"/>
</if>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${controller}</arg>
<arg>port=${karaf_port}</arg>
<arg>prompt=${KARAF_PROMPT_LOGIN}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:05:48.377651" elapsed="0.000431"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.378511" level="INFO">Logging into '10.30.170.72:8101' as 'karaf'.</msg>
<msg time="2026-04-24T02:05:48.529668" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-04-24T02:05:48.378227" elapsed="0.151564"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.551325" level="INFO">@root&gt;dropallpacketsrpc on</msg>
<arg>${cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-24T02:05:48.529995" elapsed="0.021414"/>
</kw>
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.553189" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<msg time="2026-04-24T02:05:48.553296" level="INFO">${output} = [?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<var>${output}</var>
<arg>${KARAF_PROMPT}</arg>
<doc>Consumes and returns the server output until a match to ``regexp`` is found.</doc>
<status status="PASS" start="2026-04-24T02:05:48.551562" elapsed="0.001764"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>logout\n</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-04-24T02:05:48.553478" elapsed="0.000191"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:05:48.553819" elapsed="0.000188"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:05:48.554470" level="INFO">[?1l&gt;[?2004lDropAllFlows transitions to on
[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:05:48.554146" elapsed="0.000376"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-24T02:05:48.554572" elapsed="0.000050"/>
</return>
<arg>dropallpacketsrpc on</arg>
<doc>Will execute the given ${cmd} by ssh'ing to the karaf console running on 10.30.170.72
Note that this keyword will open&amp;close new SSH connection, without switching back to previously current session.</doc>
<status status="PASS" start="2026-04-24T02:05:48.376984" elapsed="0.177775"/>
</kw>
<status status="PASS" start="2026-04-24T02:05:46.396883" elapsed="2.157946"/>
</kw>
<test id="s1-t1" name="Cbench Latency Test" line="37">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:05:48.557130" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:05:48.555962" elapsed="0.001235"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-24T02:05:48.558858" level="INFO">${output_filename} = latency.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-24T02:05:48.558481" elapsed="0.000422"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-24T02:05:48.559226" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:05:48.558983" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-24T02:05:48.562296" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:05:48.562041" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-04-24T02:05:48.562019" elapsed="0.000379"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.562742" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-24T02:05:48.562534" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:05:48.563558" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.170.72 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:05:48.563066" elapsed="0.000554"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.564275" level="INFO">${conn_id} = 5</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:05:48.563762" elapsed="0.000541"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-24T02:05:48.565249" level="INFO">Length is 0.</msg>
<msg time="2026-04-24T02:05:48.565344" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-24T02:05:48.564912" elapsed="0.000473"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:05:48.565529" elapsed="0.000342"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.566778" level="INFO">Logging into '10.30.171.38:22' as 'jenkins'.</msg>
<msg time="2026-04-24T02:05:48.906341" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Fri Apr 24 02:05:47 UTC 2026

  System load:  0.21               Processes:             111
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.38
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Fri Apr 24 02:05:47 2026 from 10.30.171.207
[?2004h[jenkins@releng-48317-699-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-24T02:05:48.566396" elapsed="0.340216"/>
</kw>
<msg time="2026-04-24T02:05:48.906765" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:05:48.566026" elapsed="0.340876"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-24T02:05:48.564524" elapsed="0.342581"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-24T02:05:48.908329" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.170.72 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-24T02:15:55.046488" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-24T02:15:55.046926" level="INFO">${stdout} = </msg>
<msg time="2026-04-24T02:15:55.047040" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-24T02:05:48.907491" elapsed="606.139611"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:15:55.047575" elapsed="0.000739"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.049571" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72: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.170.72. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:06:54.141 16  switches: flows:  96976 98954 98822 99041 98629 96833 97525 97001 97524 96653 96507 95901 96709 96375 96031 95934  total = 25.923583 per ms 
02:07:54.241 16  switches: flows:  106843 105550 103673 106920 104678 104409 106780 104960 107569 102483 105783 104075 105451 105277 101357 104437  total = 27.957372 per ms 
02:08:54.341 16  switches: flows:  92475 95992 94404 92922 92205 91803 92959 93159 91996 90958 91374 90464 91473 91771 90956 92872  total = 24.588648 per ms 
02:09:54.442 16  switches: flows:  120415 121698 122531 119164 119510 120146 119606 118463 118417 117376 115858 117371 116312 119335 118176 119100  total = 31.671736 per ms 
02:10:54.542 16  switches: flows:  119622 120278 122023 118908 118615 117843 120354 117443 117478 116972 116489 116958 114427 118007 119554 117434  total = 31.487494 per ms 
02:11:54.642 16  switches: flows:  123324 123488 126350 122131 122865 122927 123997 121497 121338 120939 118445 122330 120376 122171 120192 122060  total = 32.519480 per ms 
02:12:54.743 16  switches: flows:  124855 124487 127243 123857 123343 122306 124510 124493 121242 123451 118534 121609 122168 121709 120753 121990  total = 32.721190 per ms 
02:13:54.843 16  switches: flows:  127498 127065 130285 124499 125317 123528 126433 125273 123773 125101 120562 122860 125735 125266 123884 122714  total = 33.274192 per ms 
02:14:54.943 16  switches: flows:  125825 126088 127793 123860 123703 122027 123184 123286 122429 124014 119806 121258 123073 123061 122421 122752  total = 32.854759 per ms 
02:15:55.044 16  switches: flows:  128111 128268 130615 125738 125198 124610 125099 125192 124205 125657 121022 123662 125004 125757 123418 124394  total = 33.376717 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 24588.65/33376.72/31161.29/10756.78 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.048728" elapsed="0.001143"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-24T02:15:55.050432" elapsed="0.000080"/>
</return>
<status status="PASS" start="2026-04-24T02:15:55.050081" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-04-24T02:15:55.050021" elapsed="0.000637"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-24T02:15:55.050890" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-04-24T02:15:55.050801" elapsed="0.000186"/>
</branch>
<status status="NOT RUN" start="2026-04-24T02:15:55.050764" elapsed="0.000274"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-24T02:15:55.051117" elapsed="0.000032"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:15:55.057099" elapsed="0.000854"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:15:55.058302" elapsed="0.000406"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:15:55.058861" elapsed="0.000097"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-24T02:15:55.051884" elapsed="0.007126"/>
</kw>
<msg time="2026-04-24T02:15:55.059138" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-24T02:05:48.559667" elapsed="606.499498"/>
</kw>
<status status="PASS" start="2026-04-24T02:05:48.559316" elapsed="606.499899"/>
</branch>
<status status="PASS" start="2026-04-24T02:05:48.558959" elapsed="606.500280"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.059680" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72: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.170.72. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:06:54.141 16  switches: flows:  96976 98954 98822 99041 98629 96833 97525 97001 97524 96653 96507 95901 96709 96375 96031 95934  total = 25.923583 per ms 
02:07:54.241 16  switches: flows:  106843 105550 103673 106920 104678 104409 106780 104960 107569 102483 105783 104075 105451 105277 101357 104437  total = 27.957372 per ms 
02:08:54.341 16  switches: flows:  92475 95992 94404 92922 92205 91803 92959 93159 91996 90958 91374 90464 91473 91771 90956 92872  total = 24.588648 per ms 
02:09:54.442 16  switches: flows:  120415 121698 122531 119164 119510 120146 119606 118463 118417 117376 115858 117371 116312 119335 118176 119100  total = 31.671736 per ms 
02:10:54.542 16  switches: flows:  119622 120278 122023 118908 118615 117843 120354 117443 117478 116972 116489 116958 114427 118007 119554 117434  total = 31.487494 per ms 
02:11:54.642 16  switches: flows:  123324 123488 126350 122131 122865 122927 123997 121497 121338 120939 118445 122330 120376 122171 120192 122060  total = 32.519480 per ms 
02:12:54.743 16  switches: flows:  124855 124487 127243 123857 123343 122306 124510 124493 121242 123451 118534 121609 122168 121709 120753 121990  total = 32.721190 per ms 
02:13:54.843 16  switches: flows:  127498 127065 130285 124499 125317 123528 126433 125273 123773 125101 120562 122860 125735 125266 123884 122714  total = 33.274192 per ms 
02:14:54.943 16  switches: flows:  125825 126088 127793 123860 123703 122027 123184 123286 122429 124014 119806 121258 123073 123061 122421 122752  total = 32.854759 per ms 
02:15:55.044 16  switches: flows:  128111 128268 130615 125738 125198 124610 125099 125192 124205 125657 121022 123662 125004 125757 123418 124394  total = 33.376717 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 24588.65/33376.72/31161.29/10756.78 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.059389" elapsed="0.000369"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-24T02:15:55.059905" elapsed="0.000361"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-24T02:15:55.060664" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-24T02:15:55.060754" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 24588.65/33376.72/31161.29/10756.78 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-24T02:15:55.060440" elapsed="0.000339"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:15:55.061186" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 24588.65/33376.72/31161.29/10756.78 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:15:55.060931" elapsed="0.000282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.063585" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.061355" elapsed="0.002286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.065979" level="INFO">24588.65/33376.72/31161.29/10756.78</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.063785" elapsed="0.002250"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:15:55.068346" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:15:55.066181" elapsed="0.002207"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:15:55.070759" level="INFO">@{result_value_list} = [ 24588.65 | 33376.72 | 31161.29 | 10756.78 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:15:55.068573" elapsed="0.002213"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.071238" level="INFO">Length is 4.</msg>
<msg time="2026-04-24T02:15:55.071326" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-24T02:15:55.070938" elapsed="0.000412"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.075993" level="INFO">min :: 24588.65</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.071750" elapsed="0.004300"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-24T02:15:55.071620" elapsed="0.004465"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.080544" level="INFO">max :: 33376.72</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.076301" elapsed="0.004300"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-24T02:15:55.076175" elapsed="0.004460"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.085088" level="INFO">avg :: 31161.29</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.080852" elapsed="0.004292"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-24T02:15:55.080725" elapsed="0.004454"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.089650" level="INFO">stdev :: 10756.78</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.085412" elapsed="0.004294"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-24T02:15:55.085271" elapsed="0.004469"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-24T02:15:55.071433" elapsed="0.018339"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.093603" level="INFO">${min} = 24588.65</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:15:55.089928" elapsed="0.003706"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.097721" level="INFO">${max} = 33376.72</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:15:55.093789" elapsed="0.003960"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.101703" level="INFO">${average} = 31161.29</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:15:55.097903" elapsed="0.003827"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.105558" level="INFO">${stdev} = 10756.78</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:15:55.101879" elapsed="0.003732"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.106117" level="INFO">${date} = 2026-04-24 02:15:55</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-24T02:15:55.105769" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.106722" level="INFO">CBench Result: 2026-04-24 02:15:55,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,24588.65,33376.72,31161.29,10756.78</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.106286" elapsed="0.000490"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-24T02:15:55.107782" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/latency.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-24T02:15:55.107395" elapsed="0.000453"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-24T02:15:55.107999" elapsed="0.000465"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-24T02:15:55.106914" elapsed="0.001612"/>
</kw>
<arg>-m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${latency_threshold}</arg>
<arg>${latency_results_file}</arg>
<status status="PASS" start="2026-04-24T02:05:48.557791" elapsed="606.550794"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.109049" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-24T02:15:55.108735" elapsed="0.000369"/>
</kw>
<kw name="Log Results As Zero If Cbench Timed Out" type="TEARDOWN">
<kw name="Run Keyword If Timeout Occurred" owner="BuiltIn">
<arg>Log Results And Determine Status</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>${output_filename}</arg>
<doc>Runs the given keyword if either a test or a keyword timeout has occurred.</doc>
<status status="PASS" start="2026-04-24T02:15:55.109651" elapsed="0.000268"/>
</kw>
<status status="PASS" start="2026-04-24T02:15:55.109312" elapsed="0.000676"/>
</kw>
<doc>cbench executed in default latency mode. Test parameters have defaults, but can be overridden
on the pybot command line</doc>
<tag>cbench</tag>
<tag>latency</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-24T02:05:48.554987" elapsed="606.555038"/>
</test>
<test id="s1-t2" name="Cbench Throughput Test" line="51">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.111659" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.111134" elapsed="0.000582"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.112943" level="INFO">${output_filename} = throughput.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-24T02:15:55.112616" elapsed="0.000369"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-24T02:15:55.113335" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:15:55.113096" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Run Command On Remote System" owner="Utils">
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot; and &quot;${return_stderr}&quot;!=&quot;True&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>At least one of {return_stdout} or {return_stderr} args should be set to True</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-24T02:15:55.116663" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:15:55.116421" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-04-24T02:15:55.116402" elapsed="0.000344"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-24T02:15:55.117064" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-24T02:15:55.116874" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.117809" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.170.72 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:15:55.117339" elapsed="0.000526"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-24T02:15:55.118428" level="INFO">${conn_id} = 7</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:15:55.118003" elapsed="0.000462"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-24T02:15:55.119404" level="INFO">Length is 0.</msg>
<msg time="2026-04-24T02:15:55.119495" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-24T02:15:55.119065" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:15:55.119660" elapsed="0.000330"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-24T02:15:55.120853" level="INFO">Logging into '10.30.171.38:22' as 'jenkins'.</msg>
<msg time="2026-04-24T02:15:55.725209" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Fri Apr 24 02:15:55 UTC 2026

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


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Fri Apr 24 02:05:48 2026 from 10.30.171.207
[?2004h[jenkins@releng-48317-699-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-24T02:15:55.120501" elapsed="0.604930"/>
</kw>
<msg time="2026-04-24T02:15:55.725549" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:15:55.120142" elapsed="0.605502"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-24T02:15:55.118674" elapsed="0.607090"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-24T02:15:55.726391" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.170.72 -t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-24T02:26:02.990313" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-24T02:26:02.990792" level="INFO">${stdout} = </msg>
<msg time="2026-04-24T02:26:02.990894" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.170.72:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with ...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-24T02:15:55.726040" elapsed="607.264909"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:26:02.991398" elapsed="0.000692"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:02.993222" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.170.72: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.170.72. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:17:00.851 16  switches: flows:  494489 476631 470224 486026 478589 477819 483756 502368 465832 489592 490069 470556 496236 488759 493776 465883  total = 128.843417 per ms 
02:18:00.951 16  switches: flows:  522189 522734 525156 536038 518567 525303 523100 525412 521767 517399 524949 523977 524734 527149 522051 523827  total = 139.505236 per ms 
02:19:01.053 16  switches: flows:  515977 524598 515377 521209 513425 516444 514919 512427 513048 512809 522399 426572 524076 513012 526936 515460  total = 136.248536 per ms 
02:20:02.381 16  switches: flows:  547400 550321 536258 540744 539252 509764 551643 538897 538476 536353 522621 534829 542801 514811 541691 538820  total = 139.980171 per ms 
02:21:02.482 16  switches: flows:  494260 512252 514599 501004 502749 503534 507470 504321 507040 497069 509102 509232 499943 505663 492898 502675  total = 134.170694 per ms 
02:22:02.584 16  switches: flows:  573948 574200 575397 577830 576710 578583 571997 573624 572187 570433 573144 573839 580600 573706 580672 578336  total = 153.161946 per ms 
02:23:02.685 16  switches: flows:  564107 561896 557956 563951 550363 553374 560003 554857 545608 551972 563469 558696 563940 561540 550748 570550  total = 148.633829 per ms 
02:24:02.786 16  switches: flows:  564152 527155 530637 514490 559433 494156 490323 556795 491808 511818 542862 551630 541283 572345 570947 500900  total = 141.772826 per ms 
02:25:02.887 16  switches: flows:  565012 560823 567463 560061 555314 559443 566085 565901 561076 560370 561825 572680 562240 561230 553531 559790  total = 149.629249 per ms 
02:26:02.988 16  switches: flows:  616951 624037 609773 617293 613887 610568 625674 616424 608738 614815 613544 632309 609048 615434 606550 616122  total = 163.911098 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 134170.69/163911.10/145223.73/49225.14 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:02.992501" elapsed="0.001107"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-24T02:26:02.994142" elapsed="0.000124"/>
</return>
<status status="PASS" start="2026-04-24T02:26:02.993795" elapsed="0.000609"/>
</branch>
<status status="PASS" start="2026-04-24T02:26:02.993744" elapsed="0.000723"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-24T02:26:02.994694" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-04-24T02:26:02.994607" elapsed="0.000182"/>
</branch>
<status status="NOT RUN" start="2026-04-24T02:26:02.994567" elapsed="0.000271"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-24T02:26:02.994908" elapsed="0.000031"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:26:02.998942" elapsed="0.000507"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:26:02.999656" elapsed="0.000257"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:26:03.000099" elapsed="0.000145"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-24T02:26:02.995674" elapsed="0.004644"/>
</kw>
<msg time="2026-04-24T02:26:03.000519" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.170.72:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with ...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-24T02:15:55.114032" elapsed="607.886525"/>
</kw>
<status status="PASS" start="2026-04-24T02:15:55.113483" elapsed="607.887141"/>
</branch>
<status status="PASS" start="2026-04-24T02:15:55.113074" elapsed="607.887581"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.001252" level="INFO">cbench: controller benchmarking tool
   running in mode 'throughput'
   connecting to controller at 10.30.170.72: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.170.72. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:17:00.851 16  switches: flows:  494489 476631 470224 486026 478589 477819 483756 502368 465832 489592 490069 470556 496236 488759 493776 465883  total = 128.843417 per ms 
02:18:00.951 16  switches: flows:  522189 522734 525156 536038 518567 525303 523100 525412 521767 517399 524949 523977 524734 527149 522051 523827  total = 139.505236 per ms 
02:19:01.053 16  switches: flows:  515977 524598 515377 521209 513425 516444 514919 512427 513048 512809 522399 426572 524076 513012 526936 515460  total = 136.248536 per ms 
02:20:02.381 16  switches: flows:  547400 550321 536258 540744 539252 509764 551643 538897 538476 536353 522621 534829 542801 514811 541691 538820  total = 139.980171 per ms 
02:21:02.482 16  switches: flows:  494260 512252 514599 501004 502749 503534 507470 504321 507040 497069 509102 509232 499943 505663 492898 502675  total = 134.170694 per ms 
02:22:02.584 16  switches: flows:  573948 574200 575397 577830 576710 578583 571997 573624 572187 570433 573144 573839 580600 573706 580672 578336  total = 153.161946 per ms 
02:23:02.685 16  switches: flows:  564107 561896 557956 563951 550363 553374 560003 554857 545608 551972 563469 558696 563940 561540 550748 570550  total = 148.633829 per ms 
02:24:02.786 16  switches: flows:  564152 527155 530637 514490 559433 494156 490323 556795 491808 511818 542862 551630 541283 572345 570947 500900  total = 141.772826 per ms 
02:25:02.887 16  switches: flows:  565012 560823 567463 560061 555314 559443 566085 565901 561076 560370 561825 572680 562240 561230 553531 559790  total = 149.629249 per ms 
02:26:02.988 16  switches: flows:  616951 624037 609773 617293 613887 610568 625674 616424 608738 614815 613544 632309 609048 615434 606550 616122  total = 163.911098 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 134170.69/163911.10/145223.73/49225.14 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.000851" elapsed="0.000502"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-24T02:26:03.001579" elapsed="0.000500"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-24T02:26:03.002627" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-24T02:26:03.002751" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 134170.69/163911.10/145223.73/49225.14 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-24T02:26:03.002297" elapsed="0.000489"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:26:03.003342" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 134170.69/163911.10/145223.73/49225.14 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:26:03.002996" elapsed="0.000402"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.005970" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.003598" elapsed="0.002428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.008410" level="INFO">134170.69/163911.10/145223.73/49225.14</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.006169" elapsed="0.002299"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:26:03.010774" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:26:03.008619" elapsed="0.002182"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:26:03.013222" level="INFO">@{result_value_list} = [ 134170.69 | 163911.10 | 145223.73 | 49225.14 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:26:03.010997" elapsed="0.002253"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.013730" level="INFO">Length is 4.</msg>
<msg time="2026-04-24T02:26:03.013818" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-24T02:26:03.013419" elapsed="0.000424"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.018490" level="INFO">min :: 134170.69</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.014228" elapsed="0.004319"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-24T02:26:03.014102" elapsed="0.004479"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.023377" level="INFO">max :: 163911.10</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.018796" elapsed="0.004642"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-24T02:26:03.018670" elapsed="0.004804"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.028092" level="INFO">avg :: 145223.73</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.023687" elapsed="0.004464"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-24T02:26:03.023560" elapsed="0.004626"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.032831" level="INFO">stdev :: 49225.14</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.028420" elapsed="0.004489"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-24T02:26:03.028275" elapsed="0.004682"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-24T02:26:03.013907" elapsed="0.019089"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.037269" level="INFO">${min} = 134170.69</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:26:03.033227" elapsed="0.004073"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.041388" level="INFO">${max} = 163911.10</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:26:03.037518" elapsed="0.003903"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.045343" level="INFO">${average} = 145223.73</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:26:03.041582" elapsed="0.003805"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.049231" level="INFO">${stdev} = 49225.14</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:26:03.045541" elapsed="0.003718"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.050018" level="INFO">${date} = 2026-04-24 02:26:03</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-24T02:26:03.049434" elapsed="0.000612"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.050660" level="INFO">CBench Result: 2026-04-24 02:26:03,-t -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,134170.69,163911.10,145223.73,49225.14</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.050203" elapsed="0.000518"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-24T02:26:03.051876" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/throughput.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-24T02:26:03.051397" elapsed="0.000554"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-24T02:26:03.052111" elapsed="0.000518"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-24T02:26:03.050887" elapsed="0.001810"/>
</kw>
<arg>-t -m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${throughput_threshold}</arg>
<arg>${throughput_results_file}</arg>
<status status="PASS" start="2026-04-24T02:15:55.112022" elapsed="607.940737"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.053274" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-24T02:26:03.052910" elapsed="0.000437"/>
</kw>
<kw name="Log Results As Zero If Cbench Timed Out" type="TEARDOWN">
<kw name="Run Keyword If Timeout Occurred" owner="BuiltIn">
<arg>Log Results And Determine Status</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>0</arg>
<arg>${output_filename}</arg>
<doc>Runs the given keyword if either a test or a keyword timeout has occurred.</doc>
<status status="PASS" start="2026-04-24T02:26:03.053906" elapsed="0.000272"/>
</kw>
<status status="PASS" start="2026-04-24T02:26:03.053602" elapsed="0.000647"/>
</kw>
<doc>cbench executed in throughput mode (-t). Test parameters have defaults, but can be overridden
on the pybot command line</doc>
<tag>cbench</tag>
<tag>throughput</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-24T02:15:55.110576" elapsed="607.943710"/>
</test>
<test id="s1-t3" name="Rerun Latency Test To Check Bug 6176" line="65">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.055931" level="INFO">Cbench tests using 10 iterations of 60 second tests. Switch Count: 16. Unique MACS to cycle: 100</msg>
<arg>Cbench tests using ${loops} iterations of ${duration_in_secs} second tests. Switch Count: ${switch_count}. Unique MACS to cycle: ${num_of_unique_macs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.055497" elapsed="0.000495"/>
</kw>
<kw name="Run Cbench And Log Results">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.057217" level="INFO">${output_filename} = bug.csv</msg>
<arg>${output_filename}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-24T02:26:03.056881" elapsed="0.000379"/>
</kw>
<if>
<branch type="IF" condition="&quot;${cbench_system}&quot; == &quot;localhost&quot;">
<kw name="Run" owner="OperatingSystem">
<var>${output}</var>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="NOT RUN" start="2026-04-24T02:26:03.057666" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:26:03.057415" 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-04-24T02:26:03.060880" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:26:03.060627" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-04-24T02:26:03.060606" elapsed="0.000356"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-24T02:26:03.061301" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-24T02:26:03.061095" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.062023" level="INFO">Attempting to execute command "/usr/local/bin/cbench -c 10.30.170.72 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633" on remote system "10.30.171.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:26:03.061602" elapsed="0.000484"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-24T02:26:03.062649" level="INFO">${conn_id} = 9</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:26:03.062226" elapsed="0.000451"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-24T02:26:03.063752" level="INFO">Length is 0.</msg>
<msg time="2026-04-24T02:26:03.063886" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-24T02:26:03.063252" elapsed="0.000665"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:26:03.064062" elapsed="0.000343"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-24T02:26:03.065257" level="INFO">Logging into '10.30.171.38:22' as 'jenkins'.</msg>
<msg time="2026-04-24T02:26:03.635463" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Fri Apr 24 02:26:03 UTC 2026

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


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Fri Apr 24 02:15:55 2026 from 10.30.171.207
[?2004h[jenkins@releng-48317-699-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-04-24T02:26:03.064902" elapsed="0.570762"/>
</kw>
<msg time="2026-04-24T02:26:03.635754" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-24T02:26:03.064558" elapsed="0.571280"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-04-24T02:26:03.062880" elapsed="0.573075"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-24T02:26:03.636609" level="INFO">Executing command '/usr/local/bin/cbench -c 10.30.170.72 -m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633'.</msg>
<msg time="2026-04-24T02:36:09.666270" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-24T02:36:09.668778" level="INFO">${stdout} = </msg>
<msg time="2026-04-24T02:36:09.668891" level="INFO">${stderr} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100...</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-24T02:26:03.636225" elapsed="606.032725"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:36:09.670273" elapsed="0.001184"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.672624" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72: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.170.72. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:27:08.759 16  switches: flows:  107634 106918 108047 104240 107973 107374 116467 107221 103612 106374 106060 103363 103377 102870 106823 105406  total = 28.395983 per ms 
02:28:08.859 16  switches: flows:  114192 114423 113877 113310 113997 113782 112432 111879 111984 113237 113058 109375 107723 110021 112054 110882  total = 29.887137 per ms 
02:29:08.960 16  switches: flows:  127321 125310 125386 123560 126410 126342 126142 123671 125550 125734 124529 123490 119665 123143 125642 125245  total = 33.230171 per ms 
02:30:09.060 16  switches: flows:  126179 124615 124555 123648 125941 125997 124025 125275 124963 124533 124618 123178 119765 121844 123792 125535  total = 33.085798 per ms 
02:31:09.160 16  switches: flows:  125318 125179 123090 122341 125945 126210 122795 122748 126020 125222 123054 121587 119259 121201 123155 123040  total = 32.881089 per ms 
02:32:09.261 16  switches: flows:  126205 125867 127109 125326 127646 128162 126275 126485 125315 126964 126420 125596 121486 123082 125501 126194  total = 33.504207 per ms 
02:33:09.362 16  switches: flows:  124168 124250 124019 123141 126670 126581 123533 124892 124016 124702 124809 121676 121442 120020 124582 123886  total = 32.984696 per ms 
02:34:09.462 16  switches: flows:  125148 124608 126333 123796 125358 128440 125561 125117 123756 124802 124021 123058 119697 122570 125176 124846  total = 33.149365 per ms 
02:35:09.562 16  switches: flows:  125193 122659 123188 121084 124093 122923 122697 122498 121045 123212 120955 120666 118026 119177 122494 120860  total = 32.458574 per ms 
02:36:09.663 16  switches: flows:  128678 125573 125679 125148 126775 123705 125607 127998 122962 127042 125711 125271 120793 123083 122980 121457  total = 33.252102 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29887.14/33504.21/32714.79/10954.06 responses/s</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.671829" elapsed="0.001115"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="PASS" start="2026-04-24T02:36:09.673537" elapsed="0.000072"/>
</return>
<status status="PASS" start="2026-04-24T02:36:09.673137" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-04-24T02:36:09.673084" elapsed="0.000661"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-04-24T02:36:09.673951" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-04-24T02:36:09.673869" elapsed="0.000159"/>
</branch>
<status status="NOT RUN" start="2026-04-24T02:36:09.673834" elapsed="0.000215"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-24T02:36:09.674080" 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-04-24T02:36:09.676638" elapsed="0.000350"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-24T02:36:09.677135" elapsed="0.000179"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-24T02:36:09.677458" elapsed="0.000097"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-24T02:36:09.674428" elapsed="0.003181"/>
</kw>
<msg time="2026-04-24T02:36:09.677737" level="INFO">${output} = cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72:6633 
   faking 16 switches with 1 threads :: 10 tests each; 60000 ms per test
   with 100...</msg>
<var>${output}</var>
<arg>${cbench_system}</arg>
<arg>${cbench_executable} -c ${ODL_SYSTEM_IP} ${cbench_args}</arg>
<arg>prompt_timeout=${test_timeout}</arg>
<arg>return_stdout=False</arg>
<arg>return_stderr=True</arg>
<doc>Reduces the common work of running a command on a remote system to a single higher level
robot keyword, taking care to log in with a public key and. The command given is written and the return value
depends on the passed argument values of return_stdout (default: True) and return_stderr (default: False).
At least one should be True, or the keyword will exit and FAIL. If both are True, the resulting return value
will be a two element list containing both. Otherwise the resulting return value is a string.
No test conditions are checked.</doc>
<status status="PASS" start="2026-04-24T02:26:03.058090" elapsed="606.619674"/>
</kw>
<status status="PASS" start="2026-04-24T02:26:03.057754" elapsed="606.620058"/>
</branch>
<status status="PASS" start="2026-04-24T02:26:03.057388" elapsed="606.620447"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.678264" level="INFO">cbench: controller benchmarking tool
   running in mode 'latency'
   connecting to controller at 10.30.170.72: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.170.72. So far 1 cbench instances have initialized their switches.  Waiting for other cbench-instances
Thread-0: Total switches from ALL cbench-instances initialized.
02:27:08.759 16  switches: flows:  107634 106918 108047 104240 107973 107374 116467 107221 103612 106374 106060 103363 103377 102870 106823 105406  total = 28.395983 per ms 
02:28:08.859 16  switches: flows:  114192 114423 113877 113310 113997 113782 112432 111879 111984 113237 113058 109375 107723 110021 112054 110882  total = 29.887137 per ms 
02:29:08.960 16  switches: flows:  127321 125310 125386 123560 126410 126342 126142 123671 125550 125734 124529 123490 119665 123143 125642 125245  total = 33.230171 per ms 
02:30:09.060 16  switches: flows:  126179 124615 124555 123648 125941 125997 124025 125275 124963 124533 124618 123178 119765 121844 123792 125535  total = 33.085798 per ms 
02:31:09.160 16  switches: flows:  125318 125179 123090 122341 125945 126210 122795 122748 126020 125222 123054 121587 119259 121201 123155 123040  total = 32.881089 per ms 
02:32:09.261 16  switches: flows:  126205 125867 127109 125326 127646 128162 126275 126485 125315 126964 126420 125596 121486 123082 125501 126194  total = 33.504207 per ms 
02:33:09.362 16  switches: flows:  124168 124250 124019 123141 126670 126581 123533 124892 124016 124702 124809 121676 121442 120020 124582 123886  total = 32.984696 per ms 
02:34:09.462 16  switches: flows:  125148 124608 126333 123796 125358 128440 125561 125117 123756 124802 124021 123058 119697 122570 125176 124846  total = 33.149365 per ms 
02:35:09.562 16  switches: flows:  125193 122659 123188 121084 124093 122923 122697 122498 121045 123212 120955 120666 118026 119177 122494 120860  total = 32.458574 per ms 
02:36:09.663 16  switches: flows:  128678 125573 125679 125148 126775 123705 125607 127998 122962 127042 125711 125271 120793 123083 122980 121457  total = 33.252102 per ms 
RESULT: 16 switches 9 tests min/max/avg/stdev = 29887.14/33504.21/32714.79/10954.06 responses/s</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.677977" elapsed="0.000361"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-04-24T02:36:09.678502" elapsed="0.000366"/>
</kw>
<kw name="Get Lines Containing String" owner="String">
<msg time="2026-04-24T02:36:09.679253" level="INFO">1 out of 23 lines matched.</msg>
<msg time="2026-04-24T02:36:09.679346" level="INFO">${result_line} = RESULT: 16 switches 9 tests min/max/avg/stdev = 29887.14/33504.21/32714.79/10954.06 responses/s</msg>
<var>${result_line}</var>
<arg>${output}</arg>
<arg>RESULT</arg>
<doc>Returns lines of the given ``string`` that contain the ``pattern``.</doc>
<status status="PASS" start="2026-04-24T02:36:09.679028" elapsed="0.000360"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:36:09.679797" level="INFO">@{results_list} = [ RESULT: | 16 | switches | 9 | tests | min/max/avg/stdev | = | 29887.14/33504.21/32714.79/10954.06 | responses/s ]</msg>
<var>@{results_list}</var>
<arg>${result_line}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:36:09.679541" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.682201" level="INFO">min/max/avg/stdev</msg>
<arg>${results_list[5]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.679973" elapsed="0.002285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.684778" level="INFO">29887.14/33504.21/32714.79/10954.06</msg>
<arg>${results_list[7]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.682419" elapsed="0.002415"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:36:09.687186" level="INFO">@{result_name_list} = [ min | max | avg | stdev ]</msg>
<var>@{result_name_list}</var>
<arg>${results_list[5]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:36:09.684983" elapsed="0.002230"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-04-24T02:36:09.689668" level="INFO">@{result_value_list} = [ 29887.14 | 33504.21 | 32714.79 | 10954.06 ]</msg>
<var>@{result_value_list}</var>
<arg>${results_list[7]}</arg>
<arg>/</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-04-24T02:36:09.687420" elapsed="0.002275"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.690157" level="INFO">Length is 4.</msg>
<msg time="2026-04-24T02:36:09.690244" level="INFO">${num_stats} = 4</msg>
<var>${num_stats}</var>
<arg>${result_name_list}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-04-24T02:36:09.689847" elapsed="0.000421"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.694915" level="INFO">min :: 29887.14</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.690664" elapsed="0.004307"/>
</kw>
<var name="${i}">0</var>
<status status="PASS" start="2026-04-24T02:36:09.690538" elapsed="0.004468"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.699478" level="INFO">max :: 33504.21</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.695215" elapsed="0.004319"/>
</kw>
<var name="${i}">1</var>
<status status="PASS" start="2026-04-24T02:36:09.695092" elapsed="0.004477"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.704037" level="INFO">avg :: 32714.79</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.699775" elapsed="0.004319"/>
</kw>
<var name="${i}">2</var>
<status status="PASS" start="2026-04-24T02:36:09.699651" elapsed="0.004477"/>
</iter>
<iter>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.708593" level="INFO">stdev :: 10954.06</msg>
<arg>${result_name_list[${i}]} :: ${result_value_list[${i}]}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.704338" elapsed="0.004311"/>
</kw>
<var name="${i}">3</var>
<status status="PASS" start="2026-04-24T02:36:09.704211" elapsed="0.004472"/>
</iter>
<var>${i}</var>
<value>0</value>
<value>${num_stats}</value>
<status status="PASS" start="2026-04-24T02:36:09.690335" elapsed="0.018378"/>
</for>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.712574" level="INFO">${min} = 29887.14</msg>
<var>${min}</var>
<arg>${result_value_list[${0}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:36:09.708879" elapsed="0.003723"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.717249" level="INFO">${max} = 33504.21</msg>
<var>${max}</var>
<arg>${result_value_list[${1}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:36:09.712756" elapsed="0.004521"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.721130" level="INFO">${average} = 32714.79</msg>
<var>${average}</var>
<arg>${result_value_list[${2}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:36:09.717472" elapsed="0.003685"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.725030" level="INFO">${stdev} = 10954.06</msg>
<var>${stdev}</var>
<arg>${result_value_list[${3}]}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-24T02:36:09.721310" elapsed="0.003747"/>
</kw>
<kw name="Get Time" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.725594" level="INFO">${date} = 2026-04-24 02:36:09</msg>
<var>${date}</var>
<arg>d,m,s</arg>
<doc>Returns the given time in the requested format.</doc>
<status status="PASS" start="2026-04-24T02:36:09.725215" elapsed="0.000406"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.726177" level="INFO">CBench Result: 2026-04-24 02:36:09,-m 60000 -M 100 -S 16 -l 10 -D 5000 -p 6633,29887.14,33504.21,32714.79,10954.06</msg>
<arg>CBench Result: ${date},${cbench_args},${min},${max},${average},${stdev}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-24T02:36:09.725771" elapsed="0.000462"/>
</kw>
<kw name="Log Results And Determine Status">
<kw name="Append To File" owner="OperatingSystem">
<msg time="2026-04-24T02:36:09.727306" level="INFO" html="true">Appended to file '&lt;a href="file:///w/workspace/openflowplugin-csit-1node-cbench-only-titanium/bug.csv"&gt;/w/workspace/openflowplugin-csit-1node-cbench-only-titanium/bug.csv&lt;/a&gt;'.</msg>
<arg>${output_file}</arg>
<arg>${min},${max},${average}\n</arg>
<doc>Appends the given content to the specified file.</doc>
<status status="PASS" start="2026-04-24T02:36:09.726852" elapsed="0.000538"/>
</kw>
<kw name="Should Be True" owner="BuiltIn">
<arg>${average} &gt; ${threshold}</arg>
<arg>${average} flow_mods per/sec did not exceed threshold of ${threshold}</arg>
<doc>Fails if the given condition is not true.</doc>
<status status="PASS" start="2026-04-24T02:36:09.727541" elapsed="0.000452"/>
</kw>
<arg>${min}</arg>
<arg>${max}</arg>
<arg>${average}</arg>
<arg>${average_threshold}</arg>
<arg>${output_filename}</arg>
<status status="PASS" start="2026-04-24T02:36:09.726385" elapsed="0.001672"/>
</kw>
<arg>-m ${duration_in_ms} -M ${num_of_unique_macs} -S ${switch_count} -l ${loops} -D ${start_delay} -p ${of_port}</arg>
<arg>${latency_threshold}</arg>
<arg>bug.csv</arg>
<status status="PASS" start="2026-04-24T02:26:03.056312" elapsed="606.671803"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.728590" level="INFO">Slept 0 seconds.</msg>
<arg>${test_delay}</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-24T02:36:09.728260" elapsed="0.000387"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-24T02:36:09.729850" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-24T02:36:09.729338" elapsed="0.000540"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-04-24T02:36:09.730097" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-04-24T02:36:09.729953" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-04-24T02:36:09.729933" elapsed="0.000250"/>
</if>
<kw name="Comment" owner="BuiltIn">
<arg>Jira tickets are {PROJECT}-{NUMBER} while Bugzilla tickets are {NUMBER}</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.730322" elapsed="0.000021"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<var>${match}</var>
<arg>Should Contain</arg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.730494" elapsed="0.000020"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${bug_url}</var>
<arg>${match}</arg>
<arg>https://jira.opendaylight.org/browse/${number}</arg>
<arg>https://bugs.opendaylight.org/show_bug.cgi?id=${number}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.730659" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>This test fails due to ${bug_url}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.730849" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.730997" elapsed="0.000025"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.731147" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.731295" elapsed="0.000019"/>
</kw>
<if>
<branch type="IF" condition="&quot;${include_bug_in_tags}&quot;==&quot;True&quot;">
<kw name="Set Tags" owner="BuiltIn">
<arg>${bug_url}</arg>
<doc>Adds given ``tags`` for the current test or all tests in a suite.</doc>
<status status="NOT RUN" start="2026-04-24T02:36:09.731528" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-04-24T02:36:09.731392" elapsed="0.000187"/>
</branch>
<status status="NOT RUN" start="2026-04-24T02:36:09.731374" elapsed="0.000228"/>
</if>
<arg>6176</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-04-24T02:36:09.729011" elapsed="0.002641"/>
</kw>
<doc>cbench executed in latency mode to see if controller is healthy</doc>
<tag>cbench</tag>
<tag>latency</tag>
<timeout value="15 minutes"/>
<status status="PASS" start="2026-04-24T02:26:03.054897" elapsed="606.676800"/>
</test>
<doc>Cbench Latency and Throughput tests can be run from an external
cbench.
If cbench is run with a medium number of switches or higher (e.g. 32+)
the normal openflow operations seem to break.
BUG: https://bugs.opendaylight.org/show_bug.cgi?id=2897</doc>
<status status="PASS" start="2026-04-24T02:05:45.844403" elapsed="1823.887870"/>
</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>
