<?xml version="1.0" encoding="UTF-8"?>
<robot generator="Robot 7.4.2 (Python 3.11.10 on linux)" generated="2026-04-21T00:47:44.459498" rpa="false" schemaversion="5">
<suite id="s1" name="jsonrpc-basic.txt" source="/w/workspace/jsonrpc-csit-1node-basic-only-vanadium/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-21T00:47:45.061634" 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-21T00:47:45.057644" elapsed="0.004033"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-04-21T00:47:45.061931" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-04-21T00:47:45.061799" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-04-21T00:47:45.061770" elapsed="0.000243"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.062720" 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-21T00:47:45.062342" elapsed="0.000430"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.063311" level="INFO">${cluster_size} = 0</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-21T00:47:45.062943" elapsed="0.000399"/>
</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-21T00:47:45.063913" elapsed="0.000358"/>
</kw>
<msg time="2026-04-21T00:47:45.064390" level="INFO">${status} = PASS</msg>
<msg time="2026-04-21T00:47:45.064445" level="INFO">${possibly_int_of_members} = 0</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-21T00:47:45.063511" elapsed="0.000961"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.065080" level="INFO">${int_of_members} = 0</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-21T00:47:45.064648" elapsed="0.000480"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.066181" 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-21T00:47:45.065879" elapsed="0.000331"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.066637" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-04-21T00:47:45.066357" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.067197" 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-21T00:47:45.066820" elapsed="0.000406"/>
</kw>
<for flavor="IN RANGE">
<iter>
<kw name="ClusterManagement__Include_Member_Index" owner="ClusterManagement">
<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="NOT RUN" start="2026-04-21T00:47:45.069721" elapsed="0.000028"/>
</kw>
<var name="${index}"/>
<status status="NOT RUN" start="2026-04-21T00:47:45.069529" elapsed="0.000271"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="NOT RUN" start="2026-04-21T00:47:45.067292" elapsed="0.002539"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.070468" level="INFO">${ClusterManagement__member_index_list} = []</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-21T00:47:45.069985" elapsed="0.000554"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.071112" level="INFO">${ClusterManagement__index_to_ip_mapping} = {}</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-21T00:47:45.070714" elapsed="0.000445"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.071663" level="INFO">${ClusterManagement__session_list} = []</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-21T00:47:45.071313" elapsed="0.000394"/>
</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-21T00:47:45.065394" elapsed="0.006378"/>
</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-21T00:47:45.056827" elapsed="0.015007"/>
</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-21T00:47:45.074416" 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-21T00:47:45.073977" elapsed="0.000479"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="PASS" start="2026-04-21T00:47:45.074741" elapsed="0.000050"/>
</return>
<status status="PASS" start="2026-04-21T00:47:45.074569" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-04-21T00:47:45.074538" elapsed="0.000335"/>
</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-21T00:47:45.075058" elapsed="0.000050"/>
</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-21T00:47:45.075288" elapsed="0.000023"/>
</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-21T00:47:45.075458" elapsed="0.000021"/>
</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-21T00:47:45.075729" elapsed="0.000024"/>
</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-21T00:47:45.076022" elapsed="0.000028"/>
</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-21T00:47:45.073385" elapsed="0.002773"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-04-21T00:47:45.076354" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-04-21T00:47:45.076231" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-04-21T00:47:45.076210" elapsed="0.000216"/>
</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-21T00:47:45.079598" level="INFO">${return_list_reference} = []</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-21T00:47:45.079179" elapsed="0.000448"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-04-21T00:47:45.080134" level="INFO">${return_list_copy} = []</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-21T00:47:45.079777" elapsed="0.000386"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-04-21T00:47:45.080210" elapsed="0.000033"/>
</return>
<msg time="2026-04-21T00:47:45.080376" level="INFO">${index_list} = []</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-21T00:47:45.078785" elapsed="0.001617"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<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="NOT RUN" start="2026-04-21T00:47:45.080761" elapsed="0.000026"/>
</kw>
<var name="${index}"/>
<status status="NOT RUN" start="2026-04-21T00:47:45.080593" elapsed="0.000232"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="NOT RUN" start="2026-04-21T00:47:45.080462" elapsed="0.000392"/>
</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-21T00:47:45.076638" elapsed="0.004273"/>
</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-21T00:47:45.081051" elapsed="0.000234"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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="NOT RUN" start="2026-04-21T00:47:45.081587" elapsed="0.000022"/>
</kw>
<var name="${index}"/>
<status status="NOT RUN" start="2026-04-21T00:47:45.081464" elapsed="0.000187"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="NOT RUN" start="2026-04-21T00:47:45.081338" elapsed="0.000340"/>
</for>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-04-21T00:47:45.072892" elapsed="0.008843"/>
</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-21T00:47:45.083917" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-04-21T00:47:45.083799" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-04-21T00:47:45.083780" elapsed="0.000211"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-04-21T00:47:45.084529" level="FAIL">Dictionary does not contain key '1'.</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="FAIL" start="2026-04-21T00:47:45.084275" elapsed="0.000453">Dictionary does not contain key '1'.</status>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<var>${current_connection_index}</var>
<arg>${karaf_connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="NOT RUN" start="2026-04-21T00:47:45.084965" elapsed="0.000023"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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="NOT RUN" start="2026-04-21T00:47:45.085150" elapsed="0.000028"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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="NOT RUN" start="2026-04-21T00:47:45.085334" elapsed="0.000022"/>
</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-21T00:47:45.085564" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-04-21T00:47:45.085433" elapsed="0.000183"/>
</branch>
<status status="NOT RUN" start="2026-04-21T00:47:45.085413" elapsed="0.000227"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message_wait}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-04-21T00:47:45.085767" elapsed="0.000021"/>
</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-21T00:47:45.085975" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-04-21T00:47:45.085850" elapsed="0.000176"/>
</branch>
<status status="NOT RUN" start="2026-04-21T00:47:45.085833" elapsed="0.000216"/>
</if>
<return>
<value>${message_wait}</value>
<status status="NOT RUN" start="2026-04-21T00:47:45.086082" elapsed="0.000031"/>
</return>
<kw name="Run Keyword If" owner="BuiltIn" type="TEARDOWN">
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords">
<msg time="2026-04-21T00:47:45.091245" level="FAIL">Variable '${current_connection_index}' not found.</msg>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="FAIL" start="2026-04-21T00:47:45.087517" elapsed="0.003767">Variable '${current_connection_index}' not found.</status>
</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="FAIL" start="2026-04-21T00:47:45.086975" elapsed="0.004377">Variable '${current_connection_index}' not found.</status>
</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="FAIL" start="2026-04-21T00:47:45.082072" elapsed="0.009374">Dictionary does not contain key '1'.

Also keyword teardown failed:
Variable '${current_connection_index}' not found.</status>
</kw>
<kw name="Mount Read Service Endpoint" owner="JsonrpcKeywords">
<doc>This keyword mounts an endpoint after starting service</doc>
<status status="NOT RUN" start="2026-04-21T00:47:45.091662" elapsed="0.000026"/>
</kw>
<kw name="Run Read Service Python Script on Controller Vm" owner="JsonrpcKeywords">
<doc>This keyword creates a new virtual environment, installs pyzmq &amp; zmq and starts the read service on controller vm</doc>
<status status="NOT RUN" start="2026-04-21T00:47:45.091996" elapsed="0.000026"/>
</kw>
<kw name="Verify Data On Mounted Endpoint" owner="JsonrpcKeywords">
<doc>This keyword verifies if the data we get on the mount point is same as what we put</doc>
<status status="NOT RUN" start="2026-04-21T00:47:45.092236" elapsed="0.000023"/>
</kw>
<doc>Push data using python utility and verify using restconf</doc>
<tag>basic data</tag>
<status status="FAIL" start="2026-04-21T00:47:45.071902" elapsed="0.020503">Dictionary does not contain key '1'.

Also keyword teardown failed:
Variable '${current_connection_index}' not found.</status>
</test>
<kw name="Delete All Sessions" owner="RequestsLibrary" type="TEARDOWN">
<msg time="2026-04-21T00:47:45.093392" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-04-21T00:47:45.093302" elapsed="0.000293"/>
</kw>
<doc>Test suite for verifying basic variations of export API including checking statuses</doc>
<status status="FAIL" start="2026-04-21T00:47:44.461174" elapsed="0.632460"/>
</suite>
<statistics>
<total>
<stat pass="0" fail="1" skip="0">All Tests</stat>
</total>
<tag>
<stat pass="0" fail="1" skip="0">basic data</stat>
</tag>
<suite>
<stat name="jsonrpc-basic.txt" id="s1" pass="0" fail="1" skip="0">jsonrpc-basic.txt</stat>
</suite>
</statistics>
<errors>
</errors>
</robot>
