<?xml version="1.0" encoding="UTF-8"?>
<robot generator="Robot 7.4.2 (Python 3.11.10 on linux)" generated="2026-04-18T02:01:01.483197" rpa="false" schemaversion="5">
<suite id="s1" name="jsonrpc-basic.txt" source="/w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/suites/jsonrpc/010-mdsal-jsonrpc-basic.robot">
<kw name="ClusterManagement_Setup" owner="ClusterManagement" type="SETUP">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.068960" level="INFO">${already_done} = False</msg>
<var>${already_done}</var>
<arg>\${ClusterManagement__has_setup_run}</arg>
<arg>False</arg>
<doc>Returns variable value or ``default`` if the variable does not exist.</doc>
<status status="PASS" start="2026-04-18T02:01:02.065161" elapsed="0.003841"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-04-18T02:01:02.069261" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:02.069133" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.069103" elapsed="0.000238"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.069851" level="INFO">${ClusterManagement__has_setup_run} = True</msg>
<arg>\${ClusterManagement__has_setup_run}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-18T02:01:02.069498" elapsed="0.000403"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.070440" level="INFO">${cluster_size} = 1</msg>
<var>${cluster_size}</var>
<arg>\${NUM_ODL_SYSTEM}</arg>
<arg>1</arg>
<doc>Returns variable value or ``default`` if the variable does not exist.</doc>
<status status="PASS" start="2026-04-18T02:01:02.070072" elapsed="0.000398"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Convert To Integer" owner="BuiltIn">
<arg>${cluster_size}</arg>
<doc>Converts the given item to an integer number.</doc>
<status status="PASS" start="2026-04-18T02:01:02.071043" elapsed="0.000328"/>
</kw>
<msg time="2026-04-18T02:01:02.071484" level="INFO">${status} = PASS</msg>
<msg time="2026-04-18T02:01:02.071537" level="INFO">${possibly_int_of_members} = 1</msg>
<var>${status}</var>
<var>${possibly_int_of_members}</var>
<arg>BuiltIn.Convert_To_Integer</arg>
<arg>${cluster_size}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:02.070643" elapsed="0.000921"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.072146" level="INFO">${int_of_members} = 1</msg>
<var>${int_of_members}</var>
<arg>'${status}' != 'PASS'</arg>
<arg>${1}</arg>
<arg>${possibly_int_of_members}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-04-18T02:01:02.071737" elapsed="0.000437"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.073219" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-04-18T02:01:02.072922" elapsed="0.000326"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.073678" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-04-18T02:01:02.073402" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.074226" level="INFO">&amp;{index_to_ip_mapping} = { }</msg>
<var>&amp;{index_to_ip_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-04-18T02:01:02.073858" elapsed="0.000397"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="ClusterManagement__Include_Member_Index" owner="ClusterManagement">
<kw name="Append To List" owner="Collections">
<arg>${member_index_list}</arg>
<arg>${index}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-04-18T02:01:02.077402" elapsed="0.000234"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.078131" level="INFO">${member_ip} = 10.30.170.45</msg>
<var>${member_ip}</var>
<arg>${ODL_SYSTEM_${index}_IP}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:02.077784" elapsed="0.000376"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${index_to_ip_mapping}</arg>
<arg>${index}</arg>
<arg>${member_ip}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-04-18T02:01:02.078306" elapsed="0.000295"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.079421" level="INFO">${session} = ClusterManagement__session_1</msg>
<var>${session}</var>
<arg>ClusterManagement__session_${member_index}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:02.079118" elapsed="0.000330"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-04-18T02:01:02.079495" elapsed="0.000042"/>
</return>
<msg time="2026-04-18T02:01:02.079667" level="INFO">${session_alias} = ClusterManagement__session_1</msg>
<var>${session_alias}</var>
<arg>member_index=${index}</arg>
<doc>Return RequestsLibrary session alias pointing to node of given index.</doc>
<status status="PASS" start="2026-04-18T02:01:02.078799" elapsed="0.000893"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-04-18T02:01:02.080362" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.45:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x727dcdf53ad0&gt;, timeout=5, proxies=None, verify=False,                     debug=0 </msg>
<arg>${session_alias}</arg>
<arg>http://${member_ip}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<arg>timeout=${http_timeout}</arg>
<arg>max_retries=${http_retries}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-04-18T02:01:02.079899" elapsed="0.000623"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${session_list}</arg>
<arg>${session_alias}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-04-18T02:01:02.080690" elapsed="0.000195"/>
</kw>
<arg>${index}</arg>
<arg>${member_index_list}</arg>
<arg>${session_list}</arg>
<arg>${index_to_ip_mapping}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>http_retries=${http_retries}</arg>
<doc>Add a corresponding item based on index into the last three arguments.
Create the Http session whose alias is added to list.</doc>
<status status="PASS" start="2026-04-18T02:01:02.076720" elapsed="0.004228"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-04-18T02:01:02.076504" elapsed="0.004490"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-04-18T02:01:02.074316" elapsed="0.006712"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.081565" level="INFO">${ClusterManagement__member_index_list} = [1]</msg>
<arg>\${ClusterManagement__member_index_list}</arg>
<arg>${member_index_list}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-18T02:01:02.081200" elapsed="0.000408"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.082137" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.45'}</msg>
<arg>\${ClusterManagement__index_to_ip_mapping}</arg>
<arg>${index_to_ip_mapping}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-18T02:01:02.081758" elapsed="0.000422"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.082741" level="INFO">${ClusterManagement__session_list} = ['ClusterManagement__session_1']</msg>
<arg>\${ClusterManagement__session_list}</arg>
<arg>${session_list}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-04-18T02:01:02.082386" elapsed="0.000399"/>
</kw>
<arg>int_of_members=${int_of_members}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>http_retries=${http_retries}</arg>
<doc>Construct index list, session list and IP mapping, publish them as suite variables.</doc>
<status status="PASS" start="2026-04-18T02:01:02.072428" elapsed="0.010418"/>
</kw>
<doc>Detect repeated call, or detect number of members and initialize derived suite variables.
Http sessions are created with parameters to not waste time when ODL is no accepting connections properly.</doc>
<status status="PASS" start="2026-04-18T02:01:02.064515" elapsed="0.018393"/>
</kw>
<test id="s1-t1" name="Push MDSAL data and Verify Through Restconf" line="14">
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.084869" level="INFO">${already_done} = True</msg>
<var>${already_done}</var>
<arg>\${ClusterManagement__has_setup_run}</arg>
<arg>False</arg>
<doc>Returns variable value or ``default`` if the variable does not exist.</doc>
<status status="PASS" start="2026-04-18T02:01:02.084497" elapsed="0.000400"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="PASS" start="2026-04-18T02:01:02.085142" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-04-18T02:01:02.084976" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.084955" elapsed="0.000290"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<arg>\${ClusterManagement__has_setup_run}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:02.085393" elapsed="0.000030"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<var>${cluster_size}</var>
<arg>\${NUM_ODL_SYSTEM}</arg>
<arg>1</arg>
<doc>Returns variable value or ``default`` if the variable does not exist.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:02.085565" elapsed="0.000020"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<var>${status}</var>
<var>${possibly_int_of_members}</var>
<arg>BuiltIn.Convert_To_Integer</arg>
<arg>${cluster_size}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:02.085734" elapsed="0.000020"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${int_of_members}</var>
<arg>'${status}' != 'PASS'</arg>
<arg>${1}</arg>
<arg>${possibly_int_of_members}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:02.085899" elapsed="0.000021"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<arg>int_of_members=${int_of_members}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>http_retries=${http_retries}</arg>
<doc>Construct index list, session list and IP mapping, publish them as suite variables.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:02.086157" elapsed="0.000025"/>
</kw>
<arg>http_timeout=${http_timeout}</arg>
<doc>Detect repeated call, or detect number of members and initialize derived suite variables.
Http sessions are created with parameters to not waste time when ODL is no accepting connections properly.</doc>
<status status="PASS" start="2026-04-18T02:01:02.084099" elapsed="0.002148"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-18T02:01:02.086430" elapsed="0.000067"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:02.086314" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.086295" elapsed="0.000261"/>
</if>
<kw name="Run_Bash_Command_On_List_Or_All" owner="ClusterManagement">
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.089842" level="INFO">${return_list_reference} = [1]</msg>
<var>${return_list_reference}</var>
<arg>"""${given_list}""" != ""</arg>
<arg>${given_list}</arg>
<arg>${ClusterManagement__member_index_list}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-04-18T02:01:02.089449" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.090341" level="INFO">${return_list_copy} = [1]</msg>
<var>${return_list_copy}</var>
<arg>@{return_list_reference}</arg>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-04-18T02:01:02.090016" elapsed="0.000355"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-04-18T02:01:02.090418" elapsed="0.000031"/>
</return>
<msg time="2026-04-18T02:01:02.090581" level="INFO">${index_list} = [1]</msg>
<var>${index_list}</var>
<arg>given_list=${member_index_list}</arg>
<doc>Utility to allow ${EMPTY} as default argument value, as the internal list is computed at runtime.
This keyword always returns a (shallow) copy of given or default list,
so operations with the returned list should not affect other lists.
Also note that this keyword does not consider empty list to be ${EMPTY}.</doc>
<status status="PASS" start="2026-04-18T02:01:02.089054" elapsed="0.001552"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-04-18T02:01:02.091641" level="INFO">${member_ip} = 10.30.170.45</msg>
<var>${member_ip}</var>
<arg>dictionary=${ClusterManagement__index_to_ip_mapping}</arg>
<arg>key=${member_index}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="PASS" start="2026-04-18T02:01:02.091372" elapsed="0.000295"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.092530" 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-18T02:01:02.092669" level="INFO">${current_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_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-18T02:01:02.092346" elapsed="0.000350"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run Command On Controller" owner="Utils">
<kw name="Run Keyword And Return" owner="BuiltIn">
<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-18T02:01:02.095571" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:02.094964" elapsed="0.000666"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.094944" elapsed="0.000712"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.095929" 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-18T02:01:02.096095" 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-18T02:01:02.095791" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.096674" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.45" 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-18T02:01:02.096269" elapsed="0.000454"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.097265" level="INFO">${conn_id} = 1</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-18T02:01:02.096867" elapsed="0.000425"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.099292" level="INFO">Length is 0.</msg>
<msg time="2026-04-18T02:01:02.099376" 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-18T02:01:02.098521" elapsed="0.000881"/>
</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-18T02:01:02.099552" elapsed="0.000637"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.101636" level="INFO">Logging into '10.30.170.45:22' as 'jenkins'.</msg>
<msg time="2026-04-18T02:01:02.438261" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-171-generic x86_64)

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

 System information as of Sat Apr 18 02:01:00 UTC 2026

  System load:  0.71               Processes:             129
  Usage of /:   11.1% of 77.35GB   Users logged in:       0
  Memory usage: 6%                 IPv4 address for ens3: 10.30.170.45
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

10 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-45177-693-0-builder-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-18T02:01:02.101024" elapsed="0.337408"/>
</kw>
<msg time="2026-04-18T02:01:02.438611" 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-18T02:01:02.100351" elapsed="0.338378"/>
</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-18T02:01:02.097497" elapsed="0.341356"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.439406" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-04-18T02:01:02.452195" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-04-18T02:01:02.452478" level="INFO">${stdout} = </msg>
<msg time="2026-04-18T02:01:02.452588" level="INFO">${stderr} = iptables v1.8.7 (nf_tables): unknown option "--dport"
Try `iptables -h' or 'iptables --help' for more information.
iptables-save v1.8.7 (nf_tables): Could not fetch rule set generation id: Permission ...</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-18T02:01:02.439129" elapsed="0.013519"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-18T02:01:02.453040" elapsed="0.000619"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.454758" level="INFO">iptables v1.8.7 (nf_tables): unknown option "--dport"
Try `iptables -h' or 'iptables --help' for more information.
iptables-save v1.8.7 (nf_tables): Could not fetch rule set generation id: Permission denied (you must be root)</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:02.454060" elapsed="0.000810"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-18T02:01:02.455449" elapsed="0.000042"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:02.455104" elapsed="0.000470"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.455007" elapsed="0.000625"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-04-18T02:01:02.456022" elapsed="0.000098"/>
</return>
<status status="PASS" start="2026-04-18T02:01:02.455764" elapsed="0.000442"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.455725" elapsed="0.000541"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-04-18T02:01:02.456355" elapsed="0.000038"/>
</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-18T02:01:02.460696" elapsed="0.000768"/>
</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-18T02:01:02.461686" elapsed="0.000239"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-18T02:01:02.462134" elapsed="0.000147"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-18T02:01:02.457168" elapsed="0.005191"/>
</kw>
<arg>${system}</arg>
<arg>${cmd}</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>prompt=${prompt}</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-18T02:01:02.094430" elapsed="0.368059"/>
</kw>
<msg time="2026-04-18T02:01:02.462645" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run Command On Remote System</arg>
<arg>${system}</arg>
<arg>${cmd}</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>prompt=${prompt}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:02.093876" elapsed="0.368848"/>
</kw>
<arg>@{args}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Call Run Comand On Remote System, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-04-18T02:01:02.093348" elapsed="0.369491"/>
</kw>
<msg time="2026-04-18T02:01:02.462899" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${keyword_name}</arg>
<arg>@{args}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:02.092837" elapsed="0.370127"/>
</kw>
<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-18T02:01:02.466559" elapsed="0.000429"/>
</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-18T02:01:02.467220" elapsed="0.000209"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-18T02:01:02.467617" elapsed="0.000139"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-18T02:01:02.463378" elapsed="0.004450"/>
</kw>
<msg time="2026-04-18T02:01:02.467954" level="INFO">${output} = </msg>
<var>${output}</var>
<arg>Utils.Run_Command_On_Controller</arg>
<arg>${member_ip}</arg>
<arg>${command}</arg>
<doc>Store current connection index, run keyword returning its result, restore connection in teardown.
Note that in order to avoid "got positional argument after named arguments", it is safer to use positional (not named) arguments on call.</doc>
<status status="PASS" start="2026-04-18T02:01:02.091873" elapsed="0.376116"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.468582" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:02.468235" elapsed="0.000404"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-04-18T02:01:02.468698" elapsed="0.000079"/>
</return>
<arg>command=${command}</arg>
<arg>member_index=${index}</arg>
<doc>Obtain IP, call Utils and return output. This keeps previous ssh session active.</doc>
<status status="PASS" start="2026-04-18T02:01:02.090960" elapsed="0.377954"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-04-18T02:01:02.090796" elapsed="0.378170"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-04-18T02:01:02.090661" elapsed="0.378358"/>
</for>
<arg>iptables -I INPUT -p tcp --dport ${KARAF_SHELL_PORT} -j ACCEPT; iptables-save</arg>
<doc>Cycle through indices (or all), run command on each.</doc>
<status status="PASS" start="2026-04-18T02:01:02.086783" elapsed="0.382359"/>
</kw>
<kw name="Comment" owner="BuiltIn">
<arg>First connections to Karaf console may fail, so WUKS is used. TODO: Track as a Bug.</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="PASS" start="2026-04-18T02:01:02.469297" elapsed="0.000215"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Open_Controller_Karaf_Console_On_Background" 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-18T02:01:02.482216" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:02.482097" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.482063" elapsed="0.000224"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.482578" 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-18T02:01:02.482683" level="INFO">${current_ssh_connection_object} = 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_object}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-18T02:01:02.482433" elapsed="0.000277"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.483126" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:02.482848" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:02.483549" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:02.483309" elapsed="0.000283"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-04-18T02:01:02.484336" level="FAIL">Dictionary does not contain key '1'.</msg>
<arg>${connection_index_dict}</arg>
<arg>${member_index}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="FAIL" start="2026-04-18T02:01:02.484096" elapsed="0.000462">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-04-18T02:01:02.484673" level="INFO">${status} = FAIL</msg>
<msg time="2026-04-18T02:01:02.484719" level="INFO">${old_connection_index} = Dictionary does not contain key '1'.</msg>
<var>${status}</var>
<var>${old_connection_index}</var>
<arg>Get From Dictionary</arg>
<arg>${connection_index_dict}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:02.483735" elapsed="0.001034"/>
</kw>
<if>
<branch type="IF" condition="'${status}'=='PASS'">
<kw name="Run Keywords" owner="BuiltIn">
<arg>SSHLibrary.Switch_Connection</arg>
<arg>${old_connection_index}</arg>
<arg>AND</arg>
<arg>BuiltIn.Run_Keyword_And_Ignore_Error</arg>
<arg>SSHLibrary.Write</arg>
<arg>logout</arg>
<arg>AND</arg>
<arg>BuiltIn.Run_Keyword_And_Ignore_Error</arg>
<arg>SSHLibrary.Close_Connection</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:02.485070" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:02.484854" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:02.484831" elapsed="0.000357"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-04-18T02:01:02.485951" level="INFO">${ip_address} = 10.30.170.45</msg>
<var>${ip_address}</var>
<arg>dictionary=${ClusterManagement__index_to_ip_mapping}</arg>
<arg>key=${member_index}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="PASS" start="2026-04-18T02:01:02.485682" elapsed="0.000295"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-04-18T02:01:02.486025" elapsed="0.000030"/>
</return>
<msg time="2026-04-18T02:01:02.486191" level="INFO">${odl_ip} = 10.30.170.45</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-04-18T02:01:02.485377" elapsed="0.000873"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${odl_ip}</arg>
<arg>port=${KARAF_SHELL_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-18T02:01:02.486396" elapsed="0.000422"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.487107" level="INFO">index=4
host=10.30.170.45
alias=None
port=8101
timeout=10 seconds
newline=

prompt=opendaylight-user
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-04-18T02:01:02.487211" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.45
alias=None
port=8101
timeout=10 seconds
newline=

prompt=opendaylight-user
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_error...</msg>
<var>${karaf_connection_object}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-04-18T02:01:02.486976" elapsed="0.000263"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${connection_index_dict}</arg>
<arg>${member_index}</arg>
<arg>${karaf_connection_object.index}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-04-18T02:01:02.487376" elapsed="0.002277"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-04-18T02:01:02.490071" level="INFO">Logging into '10.30.170.45:8101' as 'karaf'.</msg>
<msg time="2026-04-18T02:01:03.249790" 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-18T02:01:02.489805" elapsed="0.760153"/>
</kw>
<kw name="Run Keyword If" owner="BuiltIn" type="TEARDOWN">
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords">
<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-18T02:01:03.253339" elapsed="0.000341"/>
</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-18T02:01:03.253837" elapsed="0.000182"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-18T02:01:03.254174" elapsed="0.000111"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-18T02:01:03.251071" elapsed="0.003268"/>
</kw>
<arg>'${IS_KARAF_APPL}' == 'True'</arg>
<arg>SSHKeywords.Restore_Current_Ssh_Connection_From_Index</arg>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Runs the given keyword with the given arguments, if ``condition`` is true.</doc>
<status status="PASS" start="2026-04-18T02:01:03.250377" elapsed="0.004009"/>
</kw>
<arg>member_index=${index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for ${member_index},
close the previous connection. In any case create a new connection
to karaf console for ${member_index}, set correct prompt set and login to karaf console.
Store connection index for ${member_index} and restore the previous active connection.</doc>
<status status="PASS" start="2026-04-18T02:01:02.481758" elapsed="0.772682"/>
</kw>
<arg>3s</arg>
<arg>1s</arg>
<arg>Open_Controller_Karaf_Console_On_Background</arg>
<arg>member_index=${index}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-04-18T02:01:02.470237" elapsed="0.784251"/>
</kw>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3s</arg>
<arg>1s</arg>
<arg>Open_Controller_Karaf_Console_On_Background</arg>
<arg>member_index=${index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:02.469863" elapsed="0.784677"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-04-18T02:01:02.469736" elapsed="0.784845"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-04-18T02:01:02.469574" elapsed="0.785052"/>
</for>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-04-18T02:01:02.083645" elapsed="1.171049"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" 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-18T02:01:03.256835" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:03.256712" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:03.256686" elapsed="0.000223"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-04-18T02:01:03.257334" level="INFO">${karaf_connection_index} = 4</msg>
<var>${karaf_connection_index}</var>
<arg>${connection_index_dict}</arg>
<arg>${member_index}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="PASS" start="2026-04-18T02:01:03.257041" elapsed="0.000321"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-04-18T02:01:03.257682" level="INFO">${current_connection_index} = None</msg>
<var>${current_connection_index}</var>
<arg>${karaf_connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-04-18T02:01:03.257506" elapsed="0.000201"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-18T02:01:03.330268" level="INFO">@root&gt;log:set DEBUG org.opendaylight.jsonrpc</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-18T02:01:03.258208" elapsed="0.072190"/>
</kw>
<msg time="2026-04-18T02:01:03.330568" level="INFO">${status_write} = PASS</msg>
<msg time="2026-04-18T02:01:03.330613" level="INFO">${message_write} = @root&gt;log:set DEBUG org.opendaylight.jsonrpc
</msg>
<var>${status_write}</var>
<var>${message_write}</var>
<arg>SSHLibrary.Write</arg>
<arg>${command}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:03.257852" elapsed="0.072785"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-04-18T02:01:03.332989" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<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-18T02:01:03.331487" elapsed="0.001560"/>
</kw>
<msg time="2026-04-18T02:01:03.333164" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-04-18T02:01:03.333236" level="INFO">${message_wait} = [?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<var>${status_wait}</var>
<var>${message_wait}</var>
<arg>SSHLibrary.Read_Until_Regexp</arg>
<arg>${KARAF_PROMPT}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:03.331028" elapsed="0.002236"/>
</kw>
<if>
<branch type="IF" condition="'${status_write}' != 'PASS'">
<kw name="Fail" owner="BuiltIn">
<arg>Failed to send the command: ${command}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:03.333606" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:03.333360" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:03.333333" elapsed="0.000357"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.334112" level="INFO">[?1l&gt;[?2004l[?1h=[90m~[0m                                                                                [?2004hopendaylight-user@root&gt;</msg>
<arg>${message_wait}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:03.333823" elapsed="0.000339"/>
</kw>
<if>
<branch type="IF" condition="'${status_wait}' != 'PASS'">
<kw name="Fail" owner="BuiltIn">
<arg>Failed to see prompt after sending the command: ${command}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:03.334443" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:03.334230" elapsed="0.000267"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:03.334211" elapsed="0.000309"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-04-18T02:01:03.334559" elapsed="0.000044"/>
</return>
<kw name="Run Keyword If" owner="BuiltIn" type="TEARDOWN">
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords">
<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-18T02:01:03.335765" elapsed="0.000324"/>
</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-18T02:01:03.336241" elapsed="0.000397"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-18T02:01:03.336777" elapsed="0.000108"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-04-18T02:01:03.335400" elapsed="0.001538"/>
</kw>
<arg>'${IS_KARAF_APPL}' == 'True'</arg>
<arg>SSHKeywords.Restore_Current_Ssh_Connection_From_Index</arg>
<arg>${current_connection_index}</arg>
<doc>Runs the given keyword with the given arguments, if ``condition`` is true.</doc>
<status status="PASS" start="2026-04-18T02:01:03.334856" elapsed="0.002129"/>
</kw>
<arg>log:set DEBUG org.opendaylight.jsonrpc</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-04-18T02:01:03.255052" elapsed="0.082047"/>
</kw>
<kw name="Mount Read Service Endpoint" owner="JsonrpcKeywords">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-04-18T02:01:03.337884" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/variables/jsonrpc/readservice_peer_payload.json"&gt;/w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/variables/jsonrpc/readservice_peer_payload.json&lt;/a&gt;'.</msg>
<msg time="2026-04-18T02:01:03.338072" level="INFO">${JSON1} = {
    "configured-endpoints": [
        {
            "name": "foo",
            "modules": [
                "jsonrpc"
            ],
            "data-config-endpoints": [
                {
        ...</msg>
<var>${JSON1}</var>
<arg>${file}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-04-18T02:01:03.337729" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.338532" level="INFO">{
    "configured-endpoints": [
        {
            "name": "foo",
            "modules": [
                "jsonrpc"
            ],
            "data-config-endpoints": [
                {
                    "path": "{}",
                    "endpoint-uri": "zmq://127.0.0.1:4444"
                }
            ],
            "data-operational-endpoints": [
                {
                    "path": "{}",
                    "endpoint-uri": "zmq://127.0.0.1:4444"
                }
            ]
        }
    ]
}
</msg>
<arg>${JSON1}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:03.338282" elapsed="0.000297"/>
</kw>
<kw name="Put_As_Json_To_Member" owner="ClusterManagement">
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.343698" level="INFO">${session} = ClusterManagement__session_1</msg>
<var>${session}</var>
<arg>ClusterManagement__session_${member_index}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:03.343401" elapsed="0.000324"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-04-18T02:01:03.343773" elapsed="0.000033"/>
</return>
<msg time="2026-04-18T02:01:03.343927" level="INFO">${session} = ClusterManagement__session_1</msg>
<var>${session}</var>
<arg>member_index=${member_index}</arg>
<doc>Return RequestsLibrary session alias pointing to node of given index.</doc>
<status status="PASS" start="2026-04-18T02:01:03.343045" elapsed="0.000907"/>
</kw>
<kw name="Put_As_Json_To_Uri" owner="TemplatedRequests">
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.349393" level="INFO">/rests/data/jsonrpc:config/configured-endpoints=foo</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:03.349046" elapsed="0.000399"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.349825" level="INFO">{
    "configured-endpoints": [
        {
            "name": "foo",
            "modules": [
                "jsonrpc"
            ],
            "data-config-endpoints": [
                {
                    "path": "{}",
                    "endpoint-uri": "zmq://127.0.0.1:4444"
                }
            ],
            "data-operational-endpoints": [
                {
                    "path": "{}",
                    "endpoint-uri": "zmq://127.0.0.1:4444"
                }
            ]
        }
    ]
}
</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:03.349587" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.350270" level="INFO">{'Content-Type': 'application/json'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:03.350007" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.350763" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:03.350518" elapsed="0.000289"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-04-18T02:01:03.351631" level="INFO">${accumulator} = {'Content-Type': 'application/json'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-04-18T02:01:03.351408" elapsed="0.000249"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-04-18T02:01:03.351978" level="INFO">${items_to_add} = []</msg>
<var>${items_to_add}</var>
<arg>${second}</arg>
<doc>Returns items of the given ``dictionary`` as a list.</doc>
<status status="PASS" start="2026-04-18T02:01:03.351796" elapsed="0.000207"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${accumulator}</arg>
<arg>@{items_to_add}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-04-18T02:01:03.352155" elapsed="0.000214"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:03.352754" level="INFO">{'Content-Type': 'application/json'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:03.352510" elapsed="0.000287"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-04-18T02:01:03.352842" elapsed="0.000035"/>
</return>
<msg time="2026-04-18T02:01:03.353006" level="INFO">${headers} = {'Content-Type': 'application/json'}</msg>
<var>${headers}</var>
<arg>first=${content_type}</arg>
<arg>second=${accept}</arg>
<doc>Take two dicts, join them, return result. Second argument values take precedence.</doc>
<status status="PASS" start="2026-04-18T02:01:03.350996" elapsed="0.002035"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="PUT On Session" owner="RequestsLibrary">
<msg time="2026-04-18T02:01:04.425041" level="INFO">PUT Request : url=http://10.30.170.45:8181/rests/data/jsonrpc:config/configured-endpoints=foo 
 path_url=/rests/data/jsonrpc:config/configured-endpoints=foo 
 headers={'User-Agent': 'python-requests/2.33.1', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Content-Length': '523', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body={
    "configured-endpoints": [
        {
            "name": "foo",
            "modules": [
                "jsonrpc"
            ],
            "data-config-endpoints": [
                {
                    "path": "{}",
                    "endpoint-uri": "zmq://127.0.0.1:4444"
                }
            ],
            "data-operational-endpoints": [
                {
                    "path": "{}",
                    "endpoint-uri": "zmq://127.0.0.1:4444"
                }
            ]
        }
    ]
}
 
 </msg>
<msg time="2026-04-18T02:01:04.425317" level="INFO">PUT Response : url=http://10.30.170.45:8181/rests/data/jsonrpc:config/configured-endpoints=foo 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node01coms288mpqta18lpogbdu3vg60.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 17-Apr-2026 02:01:04 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-04-18T02:01:04.425635" level="INFO">${response} = &lt;Response [201]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>data=${data}</arg>
<arg>headers=${headers}</arg>
<doc>Sends a PUT request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-04-18T02:01:03.355216" elapsed="1.070486"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:03.353127" elapsed="1.073552"/>
</branch>
<branch type="ELSE">
<kw name="PUT On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>data=${data}</arg>
<arg>headers=${headers}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a PUT request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:04.427431" elapsed="0.000070"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:04.426836" elapsed="0.000779"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:03.353105" elapsed="1.074562"/>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.433696" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:04.430344" elapsed="0.003457"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:04.429736" elapsed="0.004115"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:04.429681" elapsed="0.004205"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.437206" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:04.434271" elapsed="0.002999"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:04.433962" elapsed="0.003355"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:04.433939" elapsed="0.003411"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.441825" level="INFO">${status_codes_type} = list</msg>
<var>${status_codes_type}</var>
<arg>type($additional_allowed_status_codes).__name__</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-18T02:01:04.437577" elapsed="0.004276"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status_codes_type}&quot;!=&quot;list&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${allowed_status_codes_list}</var>
<arg>${additional_allowed_status_codes}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:04.442168" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:04.441928" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.442708" level="INFO">${allowed_status_codes_list} = []</msg>
<var>${allowed_status_codes_list}</var>
<arg>${additional_allowed_status_codes}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:04.442402" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:04.442252" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:04.441910" elapsed="0.000881"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.443321" level="INFO">${status_codes_type} = list</msg>
<var>${status_codes_type}</var>
<arg>type($explicit_status_codes).__name__</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-18T02:01:04.442932" elapsed="0.000416"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status_codes_type}&quot;!=&quot;list&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${explicit_status_codes_list}</var>
<arg>${explicit_status_codes}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:04.443632" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:04.443417" elapsed="0.000271"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.444175" level="INFO">${explicit_status_codes_list} = []</msg>
<var>${explicit_status_codes_list}</var>
<arg>${explicit_status_codes}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:04.443853" elapsed="0.000429"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:04.443712" elapsed="0.000609"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:04.443398" elapsed="0.000945"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${explicit_status_codes_list}""" != """${NO_STATUS_CODES}"""</arg>
<arg>Collections.List_Should_Contain_Value</arg>
<arg>${explicit_status_codes_list}</arg>
<arg>${response.status_code}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:04.444489" elapsed="0.000360"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-04-18T02:01:04.445548" level="INFO">${final_allowd_list} = [200, 201, 204]</msg>
<var>${final_allowd_list}</var>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${allowed_status_codes_list}</arg>
<doc>Combines the given ``lists`` together and returns the result.</doc>
<status status="PASS" start="2026-04-18T02:01:04.445002" elapsed="0.000573"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="PASS" start="2026-04-18T02:01:04.445719" elapsed="0.002150"/>
</kw>
<arg>${response}</arg>
<doc>Log response text, check status_code is one of allowed ones. In cases where this keyword is
called in a WUKS it could end up logging tons of data and it may be desired to skip the logging by passing
log_response=False, but by default it remains True.</doc>
<status status="PASS" start="2026-04-18T02:01:04.428660" elapsed="0.019277"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-04-18T02:01:04.448140" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:04.448007" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:04.447988" elapsed="0.000228"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-04-18T02:01:04.450563" level="INFO">${text_normalized} = </msg>
<var>${text_normalized}</var>
<arg>${response.text}</arg>
<arg>jmes_path=${jmes_path}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-04-18T02:01:04.448349" elapsed="0.002240"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-04-18T02:01:04.450639" elapsed="0.000042"/>
</return>
<msg time="2026-04-18T02:01:04.450817" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>content_type=${HEADERS_YANG_JSON}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>PUT data to given URI, check status code and return response text.
${content_type} and ${accept} are mandatory Python objects with headers to use.
If ${normalize_json}, normalize text before returning.</doc>
<status status="PASS" start="2026-04-18T02:01:03.346605" elapsed="1.104237"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-04-18T02:01:04.450906" elapsed="0.000026"/>
</return>
<msg time="2026-04-18T02:01:04.451062" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>session=${session}</arg>
<doc>Specify JSON headers and return Put_To_Uri normalized response text.
Yang json content type is used as a workaround to RequestsLibrary json conversion eagerness.</doc>
<status status="PASS" start="2026-04-18T02:01:03.344165" elapsed="1.106944"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-04-18T02:01:04.451163" elapsed="0.000027"/>
</return>
<msg time="2026-04-18T02:01:04.451324" level="INFO">${response_json} = </msg>
<var>${response_json}</var>
<arg>${READ_SERVICE_PEER_URL}=${endpoint}</arg>
<arg>${JSON1}</arg>
<arg>${controller_index}</arg>
<doc>Send a PUT with the supplied uri and data to member ${member_index}.</doc>
<status status="PASS" start="2026-04-18T02:01:03.342523" elapsed="1.108826"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.451755" level="INFO"/>
<arg>${response_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:04.451503" elapsed="0.000293"/>
</kw>
<doc>This keyword mounts an endpoint after starting service</doc>
<status status="PASS" start="2026-04-18T02:01:03.337331" elapsed="1.114527"/>
</kw>
<kw name="Run Read Service Python Script on Controller Vm" owner="JsonrpcKeywords">
<kw name="Convert To Integer" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.452840" level="INFO">${host_index} = 1</msg>
<var>${host_index}</var>
<arg>${host_index}</arg>
<doc>Converts the given item to an integer number.</doc>
<status status="PASS" start="2026-04-18T02:01:04.452521" elapsed="0.000346"/>
</kw>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-04-18T02:01:04.453672" level="INFO">${ip_address} = 10.30.170.45</msg>
<var>${ip_address}</var>
<arg>dictionary=${ClusterManagement__index_to_ip_mapping}</arg>
<arg>key=${member_index}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="PASS" start="2026-04-18T02:01:04.453402" elapsed="0.000297"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-04-18T02:01:04.453747" elapsed="0.000042"/>
</return>
<msg time="2026-04-18T02:01:04.453909" level="INFO">${host} = 10.30.170.45</msg>
<var>${host}</var>
<arg>${host_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-04-18T02:01:04.453068" elapsed="0.000866"/>
</kw>
<kw name="Open_Connection_To_ODL_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-04-18T02:01:04.458561" level="INFO">${odl_connection} = 7</msg>
<var>${odl_connection}</var>
<arg>${ip_address}</arg>
<arg>prompt=${ODL_SYSTEM_PROMPT}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-04-18T02:01:04.458135" elapsed="0.000453"/>
</kw>
<kw name="Flexible_Controller_Login" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.460459" level="INFO">Length is 0.</msg>
<msg time="2026-04-18T02:01:04.460539" 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-18T02:01:04.460012" elapsed="0.000551"/>
</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-18T02:01:04.460710" elapsed="0.000325"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-04-18T02:01:04.461905" level="INFO">Logging into '10.30.170.45:22' as 'jenkins'.</msg>
<msg time="2026-04-18T02:01:04.775319" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-171-generic x86_64)

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

 System information as of Sat Apr 18 02:01:00 UTC 2026

  System load:  0.71               Processes:             129
  Usage of /:   11.1% of 77.35GB   Users logged in:       0
  Memory usage: 6%                 IPv4 address for ens3: 10.30.170.45
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Apr 18 02:01:02 2026 from 10.30.171.221
[?2004h[jenkins@releng-45177-693-0-builder-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-18T02:01:04.461562" elapsed="0.314081"/>
</kw>
<msg time="2026-04-18T02:01:04.775748" 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-18T02:01:04.461209" elapsed="0.314639"/>
</kw>
<arg>user=${user}</arg>
<arg>password=${password}</arg>
<arg>delay=${delay}</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-18T02:01:04.459534" elapsed="0.316448"/>
</kw>
<msg time="2026-04-18T02:01:04.776039" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Flexible SSH Login</arg>
<arg>user=${user}</arg>
<arg>password=${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-18T02:01:04.459146" elapsed="0.316956"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-04-18T02:01:04.458755" elapsed="0.317428"/>
</kw>
<return>
<value>${odl_connection}</value>
<status status="PASS" start="2026-04-18T02:01:04.776244" elapsed="0.000051"/>
</return>
<msg time="2026-04-18T02:01:04.776492" level="INFO">${connections} = 7</msg>
<var>${connections}</var>
<arg>${host}</arg>
<doc>Open a connection to the ODL system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-04-18T02:01:04.457749" elapsed="0.318768"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connections}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-04-18T02:01:04.776754" elapsed="0.000204"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-04-18T02:01:04.787913" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-04-18T02:01:04.796734" level="INFO">'/w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/variables/jsonrpc/odl-jsonrpc-test-read' -&gt; '/tmp/karaf-0.22.3//odl-jsonrpc-test-read'</msg>
<arg>${READ_SERVICE_SCRIPT}</arg>
<arg>${WORKSPACE}/${BUNDLEFOLDER}/</arg>
<arg>mode=664</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-04-18T02:01:04.777116" elapsed="0.019753"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-04-18T02:01:04.797627" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/variables/jsonrpc/jsonrpcconfig_module.json"&gt;/w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/variables/jsonrpc/jsonrpcconfig_module.json&lt;/a&gt;'.</msg>
<msg time="2026-04-18T02:01:04.797928" level="INFO">${module} = {
 "jsonrpc:config": {}
}
</msg>
<var>${module}</var>
<arg>${JSONRPCCONFIG_MODULE_JSON}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-04-18T02:01:04.797265" elapsed="0.000746"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-04-18T02:01:04.798708" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/variables/jsonrpc/jsonrpcconfig_data.json"&gt;/w/workspace/jsonrpc-csit-1node-basic-only-titanium/test/csit/variables/jsonrpc/jsonrpcconfig_data.json&lt;/a&gt;'.</msg>
<msg time="2026-04-18T02:01:04.798976" level="INFO">${data} = {
    "configured-endpoints": [
        {
            "name": "foo"
        }
    ]
}
</msg>
<var>${data}</var>
<arg>${JSONRPCCONFIG_DATA_JSON}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-04-18T02:01:04.798387" elapsed="0.000645"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.805874" level="INFO">${cmd} = nohup python /tmp/karaf-0.22.3/odl-jsonrpc-test-read tcp://0.0.0.0:4444 'config' foo '{"jsonrpc:config":{}}' '{"configured-endpoints":[{"name":"foo"}]}'</msg>
<var>${cmd}</var>
<arg>nohup python ${WORKSPACE}/${BUNDLEFOLDER}/odl-jsonrpc-test-read tcp://0.0.0.0:${DEFAULT_PORT} 'config' ${DEFAULT_ENDPOINT} '${module.replace("\n","").replace(" ","")}' '${data.replace("\n","").replace(" ","")}'</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:04.799410" elapsed="0.006503"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.806568" level="INFO">nohup python /tmp/karaf-0.22.3/odl-jsonrpc-test-read tcp://0.0.0.0:4444 'config' foo '{"jsonrpc:config":{}}' '{"configured-endpoints":[{"name":"foo"}]}'</msg>
<arg>${cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:04.806211" elapsed="0.000422"/>
</kw>
<kw name="Virtual_Env_Set_Path" owner="SSHKeywords">
<kw name="Set Global Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.812883" level="INFO">${SSHKeywords__current_venv_path} = /tmp/jsonrpc_venv</msg>
<arg>\${SSHKeywords__current_venv_path}</arg>
<arg>${venv_path}</arg>
<doc>Makes a variable available globally in all tests and suites.</doc>
<status status="PASS" start="2026-04-18T02:01:04.812330" elapsed="0.000613"/>
</kw>
<arg>/tmp/jsonrpc_venv</arg>
<doc>Set ${SSHKeywords__current_venv_path} variable to ${venv_path}. Path should be absolute.</doc>
<status status="PASS" start="2026-04-18T02:01:04.811873" elapsed="0.001152"/>
</kw>
<kw name="Virtual_Env_Create_Python3" owner="SSHKeywords">
<kw name="Execute_Command_At_Cwd_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_At_Path_Should_Pass" owner="SSHKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:04.819132" level="INFO">${cd_and_command} = cd '.' &amp;&amp; python3 -m venv /tmp/jsonrpc_venv</msg>
<var>${cd_and_command}</var>
<arg>cd '${path}' &amp;&amp; ${command}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:04.818781" elapsed="0.000380"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-18T02:01:04.820671" level="INFO">Executing command 'cd '.' &amp;&amp; python3 -m venv /tmp/jsonrpc_venv'.</msg>
<msg time="2026-04-18T02:01:07.676859" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-18T02:01:07.677295" level="INFO">${stdout} = </msg>
<msg time="2026-04-18T02:01:07.677404" level="INFO">${stderr} = </msg>
<msg time="2026-04-18T02:01:07.677498" level="INFO">${rc} = 0</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<var>${rc}</var>
<arg>${command}</arg>
<arg>return_stderr=True</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-18T02:01:04.820479" elapsed="2.857075"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-04-18T02:01:07.679806" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-04-18T02:01:07.678879" elapsed="0.001036"/>
</kw>
<msg time="2026-04-18T02:01:07.680168" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-04-18T02:01:07.680271" level="INFO">${result} = None</msg>
<var>${emptiness_status}</var>
<var>${result}</var>
<arg>BuiltIn.Should_Be_Empty</arg>
<arg>${stderr}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:07.678016" elapsed="0.002307"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-04-18T02:01:07.681836" level="INFO">${success} = True</msg>
<var>${success}</var>
<arg>(${rc} == 0) and (("${emptiness_status}" == "PASS") or not ${stderr_must_be_empty})</arg>
<arg>True</arg>
<arg>False</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-04-18T02:01:07.680796" elapsed="0.001101"/>
</kw>
<if>
<branch type="IF" condition="(${log_on_success} and ${success}) or (${log_on_failure} and not ${success})">
<kw name="Log_Command_Results" owner="SSHKeywords">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:07.684493" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:07.683904" elapsed="0.000634"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:07.684960" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:07.684713" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:07.685392" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:07.685154" elapsed="0.000281"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-04-18T02:01:07.682904" elapsed="0.002585"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:07.682119" elapsed="0.003406"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:07.682036" elapsed="0.003517"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-04-18T02:01:07.685716" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:07.685610" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:07.685592" elapsed="0.000195"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-04-18T02:01:07.685928" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-04-18T02:01:07.685839" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:07.685824" elapsed="0.000198"/>
</if>
<kw name="Fail" owner="BuiltIn">
<arg>Got rc: ${rc} or stderr was not empty: ${stderr}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:07.686175" elapsed="0.000023"/>
</kw>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Execute command via the active SSH connection. For success, rc has to be zero and optionally stderr has to be empty.
Log everything, depending on arguments and success. Return either success string or stdout.
TODO: Do we want to support customizing return values the same way as SSHLibrary.Execute_Command does?</doc>
<status status="PASS" start="2026-04-18T02:01:04.819839" elapsed="2.866457"/>
</kw>
<msg time="2026-04-18T02:01:07.686350" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:04.819306" elapsed="2.867099"/>
</kw>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>A keyword similar to Execute_Command_Should_Pass which performs "cd" to ${path} before executing the python3 -m venv /tmp/jsonrpc_venv.
This is useful when rewriting bash scripts, as series of SSHLibrary.Execute_Command do not share current working directory.
TODO: Perhaps a Keyword which sets up environment variables would be useful as well.</doc>
<status status="PASS" start="2026-04-18T02:01:04.818131" elapsed="2.868359"/>
</kw>
<msg time="2026-04-18T02:01:07.686541" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_At_Path_Should_Pass</arg>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:04.814381" elapsed="2.872207"/>
</kw>
<arg>python3 -m venv ${SSHKeywords__current_venv_path}</arg>
<doc>Run Execute_Command_At_Path_Should_Pass with previously set CWD as path.</doc>
<status status="PASS" start="2026-04-18T02:01:04.813745" elapsed="2.872920"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Virtual_Env_Run_Cmd_At_Cwd" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_At_Cwd_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_At_Path_Should_Pass" owner="SSHKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:07.693312" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/jsonrpc_venv/bin/activate; pip install --upgrade pip; deactivate</msg>
<var>${cd_and_command}</var>
<arg>cd '${path}' &amp;&amp; ${command}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:07.692966" elapsed="0.000374"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-18T02:01:07.695138" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/jsonrpc_venv/bin/activate; pip install --upgrade pip; deactivate'.</msg>
<msg time="2026-04-18T02:01:09.411369" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-18T02:01:09.411827" level="INFO">${stdout} = Requirement already satisfied: pip in /tmp/jsonrpc_venv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Downloading pip-26.0.1-py3-none-any.whl (1.8 MB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━...</msg>
<msg time="2026-04-18T02:01:09.411937" level="INFO">${stderr} = </msg>
<msg time="2026-04-18T02:01:09.412028" level="INFO">${rc} = 0</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<var>${rc}</var>
<arg>${command}</arg>
<arg>return_stderr=True</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-18T02:01:07.694783" elapsed="1.717331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-04-18T02:01:09.416980" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-04-18T02:01:09.415833" elapsed="0.001452"/>
</kw>
<msg time="2026-04-18T02:01:09.417578" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-04-18T02:01:09.417674" level="INFO">${result} = None</msg>
<var>${emptiness_status}</var>
<var>${result}</var>
<arg>BuiltIn.Should_Be_Empty</arg>
<arg>${stderr}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:09.413160" elapsed="0.004564"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-04-18T02:01:09.420740" level="INFO">${success} = True</msg>
<var>${success}</var>
<arg>(${rc} == 0) and (("${emptiness_status}" == "PASS") or not ${stderr_must_be_empty})</arg>
<arg>True</arg>
<arg>False</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-04-18T02:01:09.418297" elapsed="0.002502"/>
</kw>
<if>
<branch type="IF" condition="(${log_on_success} and ${success}) or (${log_on_failure} and not ${success})">
<kw name="Log_Command_Results" owner="SSHKeywords">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:09.423640" level="INFO">Requirement already satisfied: pip in /tmp/jsonrpc_venv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Downloading pip-26.0.1-py3-none-any.whl (1.8 MB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 1.8/1.8 MB 29.0 MB/s eta 0:00:00
Installing collected packages: pip
  Attempting uninstall: pip
    Found existing installation: pip 22.0.2
    Uninstalling pip-22.0.2:
      Successfully uninstalled pip-22.0.2
Successfully installed pip-26.0.1</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:09.423278" elapsed="0.000462"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:09.424463" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:09.424055" elapsed="0.000499"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:09.425254" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:09.424868" elapsed="0.000476"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-04-18T02:01:09.422169" elapsed="0.003265"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:09.421355" elapsed="0.004220"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:09.421299" elapsed="0.004307"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-04-18T02:01:09.425819" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:09.425665" elapsed="0.000267"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:09.425647" elapsed="0.000311"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-04-18T02:01:09.426186" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-04-18T02:01:09.426012" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:09.425996" elapsed="0.000357"/>
</if>
<kw name="Fail" owner="BuiltIn">
<arg>Got rc: ${rc} or stderr was not empty: ${stderr}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:09.426489" elapsed="0.000022"/>
</kw>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Execute command via the active SSH connection. For success, rc has to be zero and optionally stderr has to be empty.
Log everything, depending on arguments and success. Return either success string or stdout.
TODO: Do we want to support customizing return values the same way as SSHLibrary.Execute_Command does?</doc>
<status status="PASS" start="2026-04-18T02:01:07.694116" elapsed="1.732546"/>
</kw>
<msg time="2026-04-18T02:01:09.426722" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:07.693489" elapsed="1.733290"/>
</kw>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>A keyword similar to Execute_Command_Should_Pass which performs "cd" to ${path} before executing the source /tmp/jsonrpc_venv/bin/activate; pip install --upgrade pip; deactivate.
This is useful when rewriting bash scripts, as series of SSHLibrary.Execute_Command do not share current working directory.
TODO: Perhaps a Keyword which sets up environment variables would be useful as well.</doc>
<status status="PASS" start="2026-04-18T02:01:07.692334" elapsed="1.734526"/>
</kw>
<msg time="2026-04-18T02:01:09.426914" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_At_Path_Should_Pass</arg>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:07.688605" elapsed="1.738355"/>
</kw>
<arg>source ${SSHKeywords__current_venv_path}/bin/activate; ${cmd}; deactivate</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Run Execute_Command_At_Path_Should_Pass with previously set CWD as path.</doc>
<status status="PASS" start="2026-04-18T02:01:07.688007" elapsed="1.739032"/>
</kw>
<msg time="2026-04-18T02:01:09.427174" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_At_Cwd_Should_Pass</arg>
<arg>source ${SSHKeywords__current_venv_path}/bin/activate; ${cmd}; deactivate</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:07.687644" elapsed="1.739577"/>
</kw>
<arg>pip install --upgrade pip</arg>
<arg>stderr_must_be_empty=False</arg>
<doc>Runs given command within activated virtual env and returns stdout.</doc>
<status status="PASS" start="2026-04-18T02:01:07.687258" elapsed="1.740040"/>
</kw>
<msg time="2026-04-18T02:01:09.427341" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${upgrade_pip}</arg>
<arg>Virtual_Env_Run_Cmd_At_Cwd</arg>
<arg>pip install --upgrade pip</arg>
<arg>stderr_must_be_empty=False</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:07.686816" elapsed="1.740569"/>
</kw>
<arg>True</arg>
<doc>Creates virtual env. If not to use the default name, use Virtual_Env_Set_Path kw. Returns stdout.</doc>
<status status="PASS" start="2026-04-18T02:01:04.813310" elapsed="4.614148"/>
</kw>
<kw name="Virtual_Env_Install_Package" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Virtual_Env_Run_Cmd_At_Cwd" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_At_Cwd_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_At_Path_Should_Pass" owner="SSHKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:09.434793" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/jsonrpc_venv/bin/activate; pip install pyzmq; deactivate</msg>
<var>${cd_and_command}</var>
<arg>cd '${path}' &amp;&amp; ${command}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:09.434453" elapsed="0.000369"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-18T02:01:09.436671" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/jsonrpc_venv/bin/activate; pip install pyzmq; deactivate'.</msg>
<msg time="2026-04-18T02:01:10.734415" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-18T02:01:10.734960" level="INFO">${stdout} = Collecting pyzmq
  Downloading pyzmq-27.1.0-cp310-cp310-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl.metadata (6.0 kB)
Downloading pyzmq-27.1.0-cp310-cp310-manylinux_2_26_x86_64.manylinux_2_28_x86_...</msg>
<msg time="2026-04-18T02:01:10.735070" level="INFO">${stderr} = </msg>
<msg time="2026-04-18T02:01:10.735230" level="INFO">${rc} = 0</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<var>${rc}</var>
<arg>${command}</arg>
<arg>return_stderr=True</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-18T02:01:09.436287" elapsed="1.299001"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-04-18T02:01:10.738855" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-04-18T02:01:10.737523" elapsed="0.001687"/>
</kw>
<msg time="2026-04-18T02:01:10.739544" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-04-18T02:01:10.739648" level="INFO">${result} = None</msg>
<var>${emptiness_status}</var>
<var>${result}</var>
<arg>BuiltIn.Should_Be_Empty</arg>
<arg>${stderr}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:10.735976" elapsed="0.003726"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-04-18T02:01:10.742167" level="INFO">${success} = True</msg>
<var>${success}</var>
<arg>(${rc} == 0) and (("${emptiness_status}" == "PASS") or not ${stderr_must_be_empty})</arg>
<arg>True</arg>
<arg>False</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-04-18T02:01:10.740246" elapsed="0.002007"/>
</kw>
<if>
<branch type="IF" condition="(${log_on_success} and ${success}) or (${log_on_failure} and not ${success})">
<kw name="Log_Command_Results" owner="SSHKeywords">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:10.746605" level="INFO">Collecting pyzmq
  Downloading pyzmq-27.1.0-cp310-cp310-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl.metadata (6.0 kB)
Downloading pyzmq-27.1.0-cp310-cp310-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (854 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 854.1/854.1 kB 19.5 MB/s  0:00:00
Installing collected packages: pyzmq
Successfully installed pyzmq-27.1.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:10.746226" elapsed="0.000474"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:10.747364" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:10.746993" elapsed="0.000454"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:10.748113" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:10.747738" elapsed="0.000465"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-04-18T02:01:10.744165" elapsed="0.004111"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:10.742561" elapsed="0.005806"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:10.742509" elapsed="0.005888"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-04-18T02:01:10.748601" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:10.748456" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:10.748438" elapsed="0.000283"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-04-18T02:01:10.748905" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-04-18T02:01:10.748775" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:10.748759" elapsed="0.000294"/>
</if>
<kw name="Fail" owner="BuiltIn">
<arg>Got rc: ${rc} or stderr was not empty: ${stderr}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:10.749307" elapsed="0.000028"/>
</kw>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Execute command via the active SSH connection. For success, rc has to be zero and optionally stderr has to be empty.
Log everything, depending on arguments and success. Return either success string or stdout.
TODO: Do we want to support customizing return values the same way as SSHLibrary.Execute_Command does?</doc>
<status status="PASS" start="2026-04-18T02:01:09.435601" elapsed="1.313876"/>
</kw>
<msg time="2026-04-18T02:01:10.749547" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:09.434972" elapsed="1.314637"/>
</kw>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>A keyword similar to Execute_Command_Should_Pass which performs "cd" to ${path} before executing the source /tmp/jsonrpc_venv/bin/activate; pip install pyzmq; deactivate.
This is useful when rewriting bash scripts, as series of SSHLibrary.Execute_Command do not share current working directory.
TODO: Perhaps a Keyword which sets up environment variables would be useful as well.</doc>
<status status="PASS" start="2026-04-18T02:01:09.433777" elapsed="1.315916"/>
</kw>
<msg time="2026-04-18T02:01:10.749746" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_At_Path_Should_Pass</arg>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:09.429881" elapsed="1.319911"/>
</kw>
<arg>source ${SSHKeywords__current_venv_path}/bin/activate; ${cmd}; deactivate</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Run Execute_Command_At_Path_Should_Pass with previously set CWD as path.</doc>
<status status="PASS" start="2026-04-18T02:01:09.429279" elapsed="1.320594"/>
</kw>
<msg time="2026-04-18T02:01:10.749922" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_At_Cwd_Should_Pass</arg>
<arg>source ${SSHKeywords__current_venv_path}/bin/activate; ${cmd}; deactivate</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:09.428781" elapsed="1.321184"/>
</kw>
<arg>pip install ${package}</arg>
<arg>stderr_must_be_empty=False</arg>
<doc>Runs given command within activated virtual env and returns stdout.</doc>
<status status="PASS" start="2026-04-18T02:01:09.428329" elapsed="1.321713"/>
</kw>
<msg time="2026-04-18T02:01:10.750161" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Virtual_Env_Run_Cmd_At_Cwd</arg>
<arg>pip install ${package}</arg>
<arg>stderr_must_be_empty=False</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:09.427941" elapsed="1.322269"/>
</kw>
<arg>pyzmq</arg>
<doc>Installs python package into virtual env. Use with version if needed (e.g. exabgp==3.4.16). Returns stdout.</doc>
<status status="PASS" start="2026-04-18T02:01:09.427652" elapsed="1.322629"/>
</kw>
<kw name="Virtual_Env_Install_Package" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Virtual_Env_Run_Cmd_At_Cwd" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_At_Cwd_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_At_Path_Should_Pass" owner="SSHKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:10.757679" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/jsonrpc_venv/bin/activate; pip install zmq; deactivate</msg>
<var>${cd_and_command}</var>
<arg>cd '${path}' &amp;&amp; ${command}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:10.757317" elapsed="0.000391"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-18T02:01:10.759492" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/jsonrpc_venv/bin/activate; pip install zmq; deactivate'.</msg>
<msg time="2026-04-18T02:01:12.880674" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-18T02:01:12.881026" level="INFO">${stdout} = Collecting zmq
  Downloading zmq-0.0.0.zip (2.2 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to build wheel: started...</msg>
<msg time="2026-04-18T02:01:12.881148" level="INFO">${stderr} = </msg>
<msg time="2026-04-18T02:01:12.881234" level="INFO">${rc} = 0</msg>
<var>${stdout}</var>
<var>${stderr}</var>
<var>${rc}</var>
<arg>${command}</arg>
<arg>return_stderr=True</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-18T02:01:10.759153" elapsed="2.122119"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-04-18T02:01:12.883490" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-04-18T02:01:12.882707" elapsed="0.000986"/>
</kw>
<msg time="2026-04-18T02:01:12.883896" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-04-18T02:01:12.883958" level="INFO">${result} = None</msg>
<var>${emptiness_status}</var>
<var>${result}</var>
<arg>BuiltIn.Should_Be_Empty</arg>
<arg>${stderr}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-04-18T02:01:12.881706" elapsed="0.002284"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-04-18T02:01:12.885377" level="INFO">${success} = True</msg>
<var>${success}</var>
<arg>(${rc} == 0) and (("${emptiness_status}" == "PASS") or not ${stderr_must_be_empty})</arg>
<arg>True</arg>
<arg>False</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-04-18T02:01:12.884299" elapsed="0.001116"/>
</kw>
<if>
<branch type="IF" condition="(${log_on_success} and ${success}) or (${log_on_failure} and not ${success})">
<kw name="Log_Command_Results" owner="SSHKeywords">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:12.888712" level="INFO">Collecting zmq
  Downloading zmq-0.0.0.zip (2.2 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to build wheel: started
  Getting requirements to build wheel: finished with status 'done'
  Preparing metadata (pyproject.toml): started
  Preparing metadata (pyproject.toml): finished with status 'done'
Requirement already satisfied: pyzmq in /tmp/jsonrpc_venv/lib/python3.10/site-packages (from zmq) (27.1.0)
Building wheels for collected packages: zmq
  Building wheel for zmq (pyproject.toml): started
  Building wheel for zmq (pyproject.toml): finished with status 'done'
  Created wheel for zmq: filename=zmq-0.0.0-py3-none-any.whl size=1087 sha256=e1487938aa40c103095bf6f31747111465798c1df1eaa63320b35ab5dc057e52
  Stored in directory: /home/jenkins/.cache/pip/wheels/ab/c5/fe/d853f71843cae26c123d37a7a5934baac20fc66f35a913951d
Successfully built zmq
Installing collected packages: zmq
Successfully installed zmq-0.0.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:12.888224" elapsed="0.000618"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:12.889745" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:12.889266" elapsed="0.000591"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:12.890737" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:12.890330" elapsed="0.000493"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-04-18T02:01:12.886602" elapsed="0.004292"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:12.885606" elapsed="0.005378"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:12.885572" elapsed="0.005440"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-04-18T02:01:12.891253" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-04-18T02:01:12.891070" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:12.891052" elapsed="0.000318"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-04-18T02:01:12.891551" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-04-18T02:01:12.891424" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:12.891408" elapsed="0.000286"/>
</if>
<kw name="Fail" owner="BuiltIn">
<arg>Got rc: ${rc} or stderr was not empty: ${stderr}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:12.891830" elapsed="0.000023"/>
</kw>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Execute command via the active SSH connection. For success, rc has to be zero and optionally stderr has to be empty.
Log everything, depending on arguments and success. Return either success string or stdout.
TODO: Do we want to support customizing return values the same way as SSHLibrary.Execute_Command does?</doc>
<status status="PASS" start="2026-04-18T02:01:10.758480" elapsed="2.133490"/>
</kw>
<msg time="2026-04-18T02:01:12.892032" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${cd_and_command}</arg>
<arg>return_success_only=False</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:10.757860" elapsed="2.134293"/>
</kw>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>A keyword similar to Execute_Command_Should_Pass which performs "cd" to ${path} before executing the source /tmp/jsonrpc_venv/bin/activate; pip install zmq; deactivate.
This is useful when rewriting bash scripts, as series of SSHLibrary.Execute_Command do not share current working directory.
TODO: Perhaps a Keyword which sets up environment variables would be useful as well.</doc>
<status status="PASS" start="2026-04-18T02:01:10.756570" elapsed="2.135749"/>
</kw>
<msg time="2026-04-18T02:01:12.892379" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_At_Path_Should_Pass</arg>
<arg>command=${command}</arg>
<arg>path=${SSHKeywords__current_remote_working_directory}</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:10.752554" elapsed="2.139873"/>
</kw>
<arg>source ${SSHKeywords__current_venv_path}/bin/activate; ${cmd}; deactivate</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Run Execute_Command_At_Path_Should_Pass with previously set CWD as path.</doc>
<status status="PASS" start="2026-04-18T02:01:10.751940" elapsed="2.140585"/>
</kw>
<msg time="2026-04-18T02:01:12.892578" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_At_Cwd_Should_Pass</arg>
<arg>source ${SSHKeywords__current_venv_path}/bin/activate; ${cmd}; deactivate</arg>
<arg>log_on_success=${log_on_success}</arg>
<arg>log_on_failure=${log_on_failure}</arg>
<arg>stderr_must_be_empty=${stderr_must_be_empty}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:10.751564" elapsed="2.141063"/>
</kw>
<arg>pip install ${package}</arg>
<arg>stderr_must_be_empty=False</arg>
<doc>Runs given command within activated virtual env and returns stdout.</doc>
<status status="PASS" start="2026-04-18T02:01:10.751152" elapsed="2.141570"/>
</kw>
<msg time="2026-04-18T02:01:12.892769" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Virtual_Env_Run_Cmd_At_Cwd</arg>
<arg>pip install ${package}</arg>
<arg>stderr_must_be_empty=False</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:10.750770" elapsed="2.142043"/>
</kw>
<arg>zmq</arg>
<doc>Installs python package into virtual env. Use with version if needed (e.g. exabgp==3.4.16). Returns stdout.</doc>
<status status="PASS" start="2026-04-18T02:01:10.750471" elapsed="2.142431"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-18T02:01:12.922976" level="INFO">source /tmp/jsonrpc_venv/bin/activate</msg>
<arg>source ${SSHKeywords__current_venv_path}/bin/activate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-18T02:01:12.893471" elapsed="0.029569"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-04-18T02:01:12.924087" level="INFO">[?2004l[?2004h(jsonrpc_venv) [jenkins@releng-45177-693-0-builder-0 ~]&gt;</msg>
<msg time="2026-04-18T02:01:12.924180" level="INFO">${output} = [?2004l[?2004h(jsonrpc_venv) [jenkins@releng-45177-693-0-builder-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-04-18T02:01:12.923249" elapsed="0.000957"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:12.924785" level="INFO">[?2004l[?2004h(jsonrpc_venv) [jenkins@releng-45177-693-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:12.924523" elapsed="0.000309"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:12.924276" elapsed="0.000590"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:12.924257" elapsed="0.000634"/>
</if>
<arg>True</arg>
<doc>Activates virtual environment. To run anything in the env activated this way you should use SSHLibrary.Write and Read commands.</doc>
<status status="PASS" start="2026-04-18T02:01:12.893160" elapsed="0.031777"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-18T02:01:12.926104" level="INFO">rm -rf nohup.out</msg>
<msg time="2026-04-18T02:01:12.926197" level="INFO">${stdout} =  rm -rf nohup.out
</msg>
<var>${stdout}</var>
<arg>rm -rf nohup.out</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-18T02:01:12.925074" elapsed="0.001149"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-18T02:01:12.928457" level="INFO">[?2004lnohup python /tmp/karaf-0.22.3/odl-jsonrpc-test-read tcp://0.0.0.0:4444 'config' foo '{"jsonrpc:config":{}}' '{"configured-endpoints":[{"name":"foo"}]}' &amp;</msg>
<msg time="2026-04-18T02:01:12.928545" level="INFO">${stdout} = [?2004lnohup python /tmp/karaf-0.22.3/odl-jsonrpc-test-read tcp://0.0.0.0:4444 'config' foo '{"jsonrpc:config":{}}' '{"configured-endpoints":[{"name":"foo"}]}' &amp;
</msg>
<var>${stdout}</var>
<arg>${cmd} &amp;</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-18T02:01:12.926383" elapsed="0.002189"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-04-18T02:01:12.931072" level="INFO">[?2004h(jsonrpc_venv) [jenkins@releng-45177-693-0-builder-0 ~]&gt; nohup python /tmp/karaf-0.22.3/odl-jsonrpc-test-read tcp://0.0.0.0:4444 'config' foo '{"jsonrpc:config":{}}' '{"configured-endpoints":[{"name":"foo"}]}' &amp;</msg>
<msg time="2026-04-18T02:01:12.931175" level="INFO">${stdout} = [?2004h(jsonrpc_venv) [jenkins@releng-45177-693-0-builder-0 ~]&gt; nohup python /tmp/karaf-0.22.3/odl-jsonrpc-test-read tcp://0.0.0.0:4444 'config' foo '{"jsonrpc:config":{}}' '{"configured-endpoints":[...</msg>
<var>${stdout}</var>
<arg>echo</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-04-18T02:01:12.928738" elapsed="0.002463"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:12.931644" level="INFO">[?2004h(jsonrpc_venv) [jenkins@releng-45177-693-0-builder-0 ~]&gt; nohup python /tmp/karaf-0.22.3/odl-jsonrpc-test-read tcp://0.0.0.0:4444 'config' foo '{"jsonrpc:config":{}}' '{"configured-endpoints":[{"name":"foo"}]}' &amp;
</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:12.931383" elapsed="0.000309"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-04-18T02:01:14.932320" level="INFO">Slept 2 seconds.</msg>
<arg>2s</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-04-18T02:01:12.931827" elapsed="2.000731"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-18T02:01:14.933462" level="INFO">Executing command '/usr/sbin/ss -nlt'.</msg>
<msg time="2026-04-18T02:01:14.946326" level="INFO">Command exited with return code 127.</msg>
<msg time="2026-04-18T02:01:14.946604" level="INFO">${stdout} = </msg>
<var>${stdout}</var>
<arg>/usr/sbin/ss -nlt</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-18T02:01:14.933148" elapsed="0.013530"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:14.947800" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:14.947120" elapsed="0.000773"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-04-18T02:01:14.948646" level="INFO">Executing command 'cat nohup.out'.</msg>
<msg time="2026-04-18T02:01:14.994272" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-04-18T02:01:14.994504" level="INFO">${stdout} = 2026-04-18T02:01:12.975681Z:INFO:root:ZMQ REP listening on tcp://0.0.0.0:4444</msg>
<var>${stdout}</var>
<arg>cat nohup.out</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-04-18T02:01:14.948431" elapsed="0.046130"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:14.995660" level="INFO">2026-04-18T02:01:12.975681Z:INFO:root:ZMQ REP listening on tcp://0.0.0.0:4444</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:14.994946" elapsed="0.000820"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-04-18T02:01:14.996116" elapsed="0.000617"/>
</kw>
<doc>This keyword creates a new virtual environment, installs pyzmq &amp; zmq and starts the read service on controller vm</doc>
<status status="PASS" start="2026-04-18T02:01:04.452201" elapsed="10.544669"/>
</kw>
<kw name="Verify Data On Mounted Endpoint" owner="JsonrpcKeywords">
<kw name="Get_From_Member" owner="ClusterManagement">
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.009997" level="INFO">${session} = ClusterManagement__session_1</msg>
<var>${session}</var>
<arg>ClusterManagement__session_${member_index}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:15.009694" elapsed="0.000330"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-04-18T02:01:15.010074" elapsed="0.000056"/>
</return>
<msg time="2026-04-18T02:01:15.010257" level="INFO">${session} = ClusterManagement__session_1</msg>
<var>${session}</var>
<arg>member_index=${member_index}</arg>
<doc>Return RequestsLibrary session alias pointing to node of given index.</doc>
<status status="PASS" start="2026-04-18T02:01:15.009359" elapsed="0.000923"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.016456" level="INFO">/rests/data/jsonrpc:config/configured-endpoints=foo/yang-ext:mount/jsonrpc:config?content=config</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:15.016208" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.016882" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:15.016641" elapsed="0.000283"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-04-18T02:01:15.224276" level="INFO">GET Request : url=http://10.30.170.45:8181/rests/data/jsonrpc:config/configured-endpoints=foo/yang-ext:mount/jsonrpc:config?content=config 
 path_url=/rests/data/jsonrpc:config/configured-endpoints=foo/yang-ext:mount/jsonrpc:config?content=config 
 headers={'User-Agent': 'python-requests/2.33.1', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01coms288mpqta18lpogbdu3vg60.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-04-18T02:01:15.225197" level="INFO">GET Response : url=http://10.30.170.45:8181/rests/data/jsonrpc:config/configured-endpoints=foo/yang-ext:mount/jsonrpc:config?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '60'} 
 body={"jsonrpc:config":{"configured-endpoints":[{"name":"foo"}]}} 
 </msg>
<msg time="2026-04-18T02:01:15.225456" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${uri}</arg>
<arg>headers=${accept}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-04-18T02:01:15.018910" elapsed="0.206604"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:15.016999" elapsed="0.208612"/>
</branch>
<branch type="ELSE">
<kw name="GET On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${uri}</arg>
<arg>headers=${accept}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:15.225997" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:15.225672" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:15.016977" elapsed="0.209250"/>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.233184" level="INFO">{"jsonrpc:config":{"configured-endpoints":[{"name":"foo"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:15.228624" elapsed="0.004607"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:15.228115" elapsed="0.005151"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:15.228032" elapsed="0.005259"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.235715" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:15.233574" elapsed="0.002187"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:15.233346" elapsed="0.002448"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:15.233330" elapsed="0.002489"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.236394" level="INFO">${status_codes_type} = list</msg>
<var>${status_codes_type}</var>
<arg>type($additional_allowed_status_codes).__name__</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-18T02:01:15.235970" elapsed="0.000451"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status_codes_type}&quot;!=&quot;list&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${allowed_status_codes_list}</var>
<arg>${additional_allowed_status_codes}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:15.236711" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:15.236490" elapsed="0.000282"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.237258" level="INFO">${allowed_status_codes_list} = []</msg>
<var>${allowed_status_codes_list}</var>
<arg>${additional_allowed_status_codes}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:15.236942" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:15.236797" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:15.236472" elapsed="0.000869"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.237851" level="INFO">${status_codes_type} = list</msg>
<var>${status_codes_type}</var>
<arg>type($explicit_status_codes).__name__</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-04-18T02:01:15.237486" elapsed="0.000392"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status_codes_type}&quot;!=&quot;list&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${explicit_status_codes_list}</var>
<arg>${explicit_status_codes}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:15.238178" elapsed="0.000071"/>
</kw>
<status status="NOT RUN" start="2026-04-18T02:01:15.237946" elapsed="0.000342"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.238754" level="INFO">${explicit_status_codes_list} = []</msg>
<var>${explicit_status_codes_list}</var>
<arg>${explicit_status_codes}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-04-18T02:01:15.238460" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-04-18T02:01:15.238313" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:15.237928" elapsed="0.000909"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${explicit_status_codes_list}""" != """${NO_STATUS_CODES}"""</arg>
<arg>Collections.List_Should_Contain_Value</arg>
<arg>${explicit_status_codes_list}</arg>
<arg>${response.status_code}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-04-18T02:01:15.238977" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-04-18T02:01:15.239836" level="INFO">${final_allowd_list} = [200, 201, 204]</msg>
<var>${final_allowd_list}</var>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${allowed_status_codes_list}</arg>
<doc>Combines the given ``lists`` together and returns the result.</doc>
<status status="PASS" start="2026-04-18T02:01:15.239528" elapsed="0.000334"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="PASS" start="2026-04-18T02:01:15.240002" elapsed="0.002277"/>
</kw>
<arg>${response}</arg>
<arg>log_response=${log_response}</arg>
<doc>Log response text, check status_code is one of allowed ones. In cases where this keyword is
called in a WUKS it could end up logging tons of data and it may be desired to skip the logging by passing
log_response=False, but by default it remains True.</doc>
<status status="PASS" start="2026-04-18T02:01:15.226993" elapsed="0.015350"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-04-18T02:01:15.242518" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-04-18T02:01:15.242411" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-04-18T02:01:15.242393" elapsed="0.000212"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<var>${text_normalized}</var>
<arg>${response.text}</arg>
<arg>jmes_path=${jmes_path}</arg>
<arg>keys_with_volatiles=${keys_with_volatiles}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="NOT RUN" start="2026-04-18T02:01:15.242738" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-04-18T02:01:15.242809" elapsed="0.000015"/>
</return>
<msg time="2026-04-18T02:01:15.244932" level="INFO">${response_text} = {"jsonrpc:config":{"configured-endpoints":[{"name":"foo"}]}}</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${access}</arg>
<arg>session=${session}</arg>
<doc>GET data from given URI, check status code and return response text.
${accept} is a Python object with headers to use.
If ${normalize_json}, normalize as JSON text before returning.</doc>
<status status="PASS" start="2026-04-18T02:01:15.010610" elapsed="0.234350"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-04-18T02:01:15.245011" elapsed="0.000027"/>
</return>
<msg time="2026-04-18T02:01:15.245177" level="INFO">${resp} = {"jsonrpc:config":{"configured-endpoints":[{"name":"foo"}]}}</msg>
<var>${resp}</var>
<arg>${READ_SERVICE_PEER_URL}=${endpoint}${READ_SERVICE_PEER_MOUNT_PATH}?content=config</arg>
<arg>${controller_index}</arg>
<doc>Send a GET with the supplied uri to member ${member_index}.</doc>
<status status="PASS" start="2026-04-18T02:01:15.008774" elapsed="0.236429"/>
</kw>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.245817" level="INFO">${response_json} = {"jsonrpc:config":{"configured-endpoints":[{"name":"foo"}]}}</msg>
<var>${response_json}</var>
<arg>${resp}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-04-18T02:01:15.245498" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-04-18T02:01:15.246263" level="INFO">{"jsonrpc:config":{"configured-endpoints":[{"name":"foo"}]}}</msg>
<arg>${response_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-04-18T02:01:15.245995" elapsed="0.000312"/>
</kw>
<kw name="Verify Restconf Get On Mounted Endpoint" owner="JsonrpcKeywords">
<kw name="Should Match Regexp" owner="BuiltIn">
<arg>${output}</arg>
<arg>"name":"${name}"</arg>
<doc>Fails if ``string`` does not match ``pattern`` as a regular expression.</doc>
<status status="PASS" start="2026-04-18T02:01:15.246821" elapsed="0.000428"/>
</kw>
<arg>${response_json}</arg>
<arg>${READSERVICE_NAME}</arg>
<doc>This keyword parses restconf get of mountpoint</doc>
<status status="PASS" start="2026-04-18T02:01:15.246467" elapsed="0.000845"/>
</kw>
<doc>This keyword verifies if the data we get on the mount point is same as what we put</doc>
<status status="PASS" start="2026-04-18T02:01:14.997406" elapsed="0.249959"/>
</kw>
<doc>Push data using python utility and verify using restconf</doc>
<tag>basic data</tag>
<status status="PASS" start="2026-04-18T02:01:02.082976" elapsed="13.164548"/>
</test>
<kw name="Delete All Sessions" owner="RequestsLibrary" type="TEARDOWN">
<msg time="2026-04-18T02:01:15.248306" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-04-18T02:01:15.248228" elapsed="0.000149"/>
</kw>
<doc>Test suite for verifying basic variations of export API including checking statuses</doc>
<status status="PASS" start="2026-04-18T02:01:01.484891" elapsed="13.763520"/>
</suite>
<statistics>
<total>
<stat pass="1" fail="0" skip="0">All Tests</stat>
</total>
<tag>
<stat pass="1" fail="0" skip="0">basic data</stat>
</tag>
<suite>
<stat name="jsonrpc-basic.txt" id="s1" pass="1" fail="0" skip="0">jsonrpc-basic.txt</stat>
</suite>
</statistics>
<errors>
</errors>
</robot>
